aboutsummaryrefslogtreecommitdiffstats
path: root/Demos/Host/ClassDriver/KeyboardHost
diff options
context:
space:
mode:
authorDean Camera <dean@fourwalledcubicle.com>2010-10-28 23:11:49 +0000
committerDean Camera <dean@fourwalledcubicle.com>2010-10-28 23:11:49 +0000
commitb8dfa976ce796ede92dfefa6a39eb0a3b08acdce (patch)
tree8144660271140732a299511aa31159c12239ee55 /Demos/Host/ClassDriver/KeyboardHost
parent2d49c09b384375298a4995b79c4b29e8d9390cd6 (diff)
downloadlufa-b8dfa976ce796ede92dfefa6a39eb0a3b08acdce.tar.gz
lufa-b8dfa976ce796ede92dfefa6a39eb0a3b08acdce.tar.bz2
lufa-b8dfa976ce796ede92dfefa6a39eb0a3b08acdce.zip
Added standard keyboard HID report scancode defines (thanks to László Monda).
Diffstat (limited to 'Demos/Host/ClassDriver/KeyboardHost')
-rw-r--r--Demos/Host/ClassDriver/KeyboardHost/KeyboardHost.c31
1 files changed, 20 insertions, 11 deletions
diff --git a/Demos/Host/ClassDriver/KeyboardHost/KeyboardHost.c b/Demos/Host/ClassDriver/KeyboardHost/KeyboardHost.c
index 1d9b2c0ff..2101ae803 100644
--- a/Demos/Host/ClassDriver/KeyboardHost/KeyboardHost.c
+++ b/Demos/Host/ClassDriver/KeyboardHost/KeyboardHost.c
@@ -123,24 +123,33 @@ int main(void)
LEDs_ChangeLEDs(LEDS_LED1, (KeyboardReport.Modifier) ? LEDS_LED1 : 0);
- uint8_t PressedKeyCode = KeyboardReport.KeyCode[0];
+ uint8_t KeyCode = KeyboardReport.KeyCode[0];
- if (PressedKeyCode)
+ if (KeyCode)
{
char PressedKey = 0;
LEDs_ToggleLEDs(LEDS_LED2);
/* Retrieve pressed key character if alphanumeric */
- if ((PressedKeyCode >= 0x04) && (PressedKeyCode <= 0x1D))
- PressedKey = (PressedKeyCode - 0x04) + 'A';
- else if ((PressedKeyCode >= 0x1E) && (PressedKeyCode <= 0x27))
- PressedKey = (PressedKeyCode - 0x1E) + '0';
- else if (PressedKeyCode == 0x2C)
- PressedKey = ' ';
- else if (PressedKeyCode == 0x28)
- PressedKey = '\n';
-
+ if ((KeyCode >= HID_KEYBOARD_SC_A) && (KeyCode <= HID_KEYBOARD_SC_Z))
+ {
+ PressedKey = (KeyCode - HID_KEYBOARD_SC_A) + 'A';
+ }
+ else if ((KeyCode >= HID_KEYBOARD_SC_1_AND_EXCLAMATION) &
+ (KeyCode <= HID_KEYBOARD_SC_0_AND_CLOSING_PARENTHESIS))
+ {
+ PressedKey = (KeyCode - HID_KEYBOARD_SC_1_AND_EXCLAMATION) + '0';
+ }
+ else if (KeyCode == HID_KEYBOARD_SC_SPACE)
+ {
+ PressedKey = ' ';
+ }
+ else if (KeyCode == HID_KEYBOARD_SC_ENTER)
+ {
+ PressedKey = '\n';
+ }
+
if (PressedKey)
putchar(PressedKey);
}