Joystick_Init();\r
LEDs_Init();\r
USB_Init();\r
+ Buttons_Init();\r
}\r
\r
/** Event handler for the USB_Connect event. This indicates that the device is enumerating via the status LEDs and\r
*/\r
void CreateKeyboardReport(USB_KeyboardReport_Data_t* ReportData)\r
{\r
- uint8_t JoyStatus_LCL = Joystick_GetStatus();\r
+ static uint8_t PrevUsedKeyCodes;\r
+ uint8_t UsedKeyCodes = 0;\r
+ uint8_t JoyStatus_LCL = Joystick_GetStatus();\r
+ uint8_t ButtonStatus_LCL = Buttons_GetStatus();\r
\r
/* Clear the report contents */\r
memset(ReportData, 0, sizeof(USB_KeyboardReport_Data_t));\r
-\r
+ \r
if (JoyStatus_LCL & JOY_UP)\r
- ReportData->KeyCode[0] = 0x04; // A\r
+ ReportData->KeyCode[UsedKeyCodes++] = 0x04; // A\r
else if (JoyStatus_LCL & JOY_DOWN)\r
- ReportData->KeyCode[0] = 0x05; // B\r
+ ReportData->KeyCode[UsedKeyCodes++] = 0x05; // B\r
\r
if (JoyStatus_LCL & JOY_LEFT)\r
- ReportData->KeyCode[0] = 0x06; // C\r
+ ReportData->KeyCode[UsedKeyCodes++] = 0x06; // C\r
else if (JoyStatus_LCL & JOY_RIGHT)\r
- ReportData->KeyCode[0] = 0x07; // D\r
+ ReportData->KeyCode[UsedKeyCodes++] = 0x07; // D\r
\r
if (JoyStatus_LCL & JOY_PRESS)\r
- ReportData->KeyCode[0] = 0x08; // E\r
+ ReportData->KeyCode[UsedKeyCodes++] = 0x08; // E\r
+ \r
+ if (ButtonStatus_LCL & BUTTONS_BUTTON1)\r
+ ReportData->KeyCode[UsedKeyCodes++] = 0x09; // F\r
+ \r
+ /* The host will ignore the device if we add a new keycode to the report while another keycode is currently\r
+ * being sent (i.e. the user has pressed another key while a key is already being pressed) - we need to intersperse\r
+ * the two reports with a zeroed report to force the host to accept the additional keys */\r
+ if (UsedKeyCodes != PrevUsedKeyCodes)\r
+ {\r
+ memset(ReportData, 0, sizeof(USB_KeyboardReport_Data_t));\r
+ PrevUsedKeyCodes = UsedKeyCodes;\r
+ }\r
}\r
\r
/** Processes a received LED report, and updates the board LEDs states to match.\r
/* Check to see if the report data has changed - if so a report MUST be sent */\r
SendReport = (memcmp(&PrevKeyboardReportData, &KeyboardReportData, sizeof(USB_KeyboardReport_Data_t)) != 0);\r
\r
- /* Save the current report data for later comparison to check for changes */\r
- PrevKeyboardReportData = KeyboardReportData;\r
- \r
/* Check if the idle period is set and has elapsed */\r
if ((IdleCount != HID_IDLE_CHANGESONLY) && (!(IdleMSRemaining)))\r
{\r
/* Check if Keyboard Endpoint Ready for Read/Write and if we should send a new report */\r
if (Endpoint_IsReadWriteAllowed() && SendReport)\r
{\r
+ /* Save the current report data for later comparison to check for changes */\r
+ PrevKeyboardReportData = KeyboardReportData;\r
+ \r
/* Write Keyboard Report Data */\r
Endpoint_Write_Stream_LE(&KeyboardReportData, sizeof(KeyboardReportData));\r
\r