Difference between revisions of "Unit Keymap"
| (12 intermediate revisions by the same user not shown) | |||
| Line 4: | Line 4: | ||
| === Description === | === Description === | ||
| ---- | ---- | ||
| + | |||
| + | '''Ultibo Keymap Interface unit''' | ||
| '''Keymaps''' | '''Keymaps''' | ||
| Line 29: | Line 31: | ||
| Dead keys account for the set of keys which behave as dead keys in any given keyboard layout. | Dead keys account for the set of keys which behave as dead keys in any given keyboard layout. | ||
| − | On pressing a deadkey it will be recognized by the keyboard as such and stored until the next key press occurs. If the next keypress is one of the resolves for the pressed dead key then  | + | On pressing a deadkey it will be recognized by the keyboard as such and stored until the next key press occurs. If the next keypress is one of the resolves for the pressed dead key then the output character will be the key code value of the resolve not for the key itself. | 
| If the next keypress after a dead key is not one of the resolves that the dead key and the pressed key will both be output to the keyboard buffer. | If the next keypress after a dead key is not one of the resolves that the dead key and the pressed key will both be output to the keyboard buffer. | ||
| Line 39: | Line 41: | ||
| All keymap units are configured to check for both the environment variable KEYMAP_DEFAULT and the global configuration variable KEYMAP_DEFAULT to determine if either of them is set to the name of that keymap. If either is set to the keymap name then that keymap will also set itself as the default during system startup. | All keymap units are configured to check for both the environment variable KEYMAP_DEFAULT and the global configuration variable KEYMAP_DEFAULT to determine if either of them is set to the name of that keymap. If either is set to the keymap name then that keymap will also set itself as the default during system startup. | ||
| − | The environment variable KEYMAP_DEFAULT can be set by adding KEYMAP_DEFAULT=XX (where XX is the name of the keymap, eg DE for Keymap_DE) to the command line of the application ( | + | The environment variable KEYMAP_DEFAULT can be set by adding KEYMAP_DEFAULT=XX (where XX is the name of the keymap, eg DE for Keymap_DE) to the command line of the application (dependent on the system, for a Raspberry Pi use the cmdline.txt file on the SD card). | 
| The global configuration variable KEYMAP_DEFAULT can be set in code by including the GlobalConfig unit in a program and setting the variable during startup. | The global configuration variable KEYMAP_DEFAULT can be set in code by including the GlobalConfig unit in a program and setting the variable during startup. | ||
| Line 48: | Line 50: | ||
| ---- | ---- | ||
| − | '' | + | |
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 20px; padding-bottom: 15px;"> | ||
| + | <div style="font-size: 14px; padding-left: 12px;">'''Keymap specific constants''' <code> KEYMAP_* </code></div> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>KEYMAP_KEY_COUNT = 256;</code> | ||
| + | | Number of key mappings in a keymap entry | ||
| + | |- | ||
| + | | <code>KEYMAP_ROW_COUNT = 4;</code> | ||
| + | | Number of mapping rows per key in a keymap entry (Normal, Shift, AltGr, Shift_AltGr) | ||
| + | |- | ||
| + | | <code>KEYMAP_ROW_SIZE = SizeOf(Word);</code> | ||
| + | |   | ||
| + | |- | ||
| + | |colspan="2"|  | ||
| + | |- | ||
| + | | <code>KEYMAP_MAX_CAPSKEYS = 50;</code> | ||
| + | | Maximum number of keys that can be listed in the TKeymapCapskeys structure | ||
| + | |- | ||
| + | | <code>KEYMAP_MAX_DEADKEYS = 5;</code> | ||
| + | | Maximum number of keys that can be listed in the TKeymapDeadkeys structure | ||
| + | |- | ||
| + | | <code>KEYMAP_MAX_RESOLVES = 20;</code> | ||
| + | | Maximum number of resolves that can be listed in the TKeymapDeadkey structure | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | <br />  | ||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 20px; padding-bottom: 15px;"> | ||
| + | <div style="font-size: 14px; padding-left: 12px;">'''Keymap signature''' <code> KEYMAP_SIGNATURE_* </code></div> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>KEYMAP_SIGNATURE = $863FDBA1;</code> | ||
| + | | style="width: 50%;"|  | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | <br /> | ||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 20px; padding-bottom: 15px;"> | ||
| + | <div style="font-size: 14px; padding-left: 12px;">'''Keymap name length''' <code> KEYMAP_*_LENGTH </code></div> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>KEYMAP_NAME_LENGTH = SIZE_64;</code> | ||
| + | | Length of keymap name | ||
| + | |- | ||
| + | | <code>KEYMAP_DESC_LENGTH = SIZE_128;</code> | ||
| + | | Length of keymap description | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | <br />  | ||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 20px; padding-bottom: 15px;"> | ||
| + | <div style="font-size: 14px; padding-left: 12px;">'''Keymap mode''' <code> KEYMAP_MODE_* </code></div> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>KEYMAP_MODE_NONE = 0;</code> | ||
| + | | style="width: 50%;"|  | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | <br />  | ||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 20px; padding-bottom: 15px;"> | ||
| + | <div style="font-size: 14px; padding-left: 12px;">'''Keymap flag''' <code> KEYMAP_FLAG_* </code></div> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>KEYMAP_FLAG_NONE = $00000000;</code> | ||
| + | |   | ||
| + | |- | ||
| + | | <code>KEYMAP_FLAG_ALTGR = $00000001;</code> | ||
| + | | The key mapping uses the AltGr key | ||
| + | |- | ||
| + | | <code>KEYMAP_FLAG_CAPS_ALL = $00000002;</code> | ||
| + | | Caps Lock shifts all characters not just alphabetic | ||
| + | |- | ||
| + | | <code>KEYMAP_FLAG_CAPS_ASCII = $00000004;</code> | ||
| + | | Caps Lock shifts only ASCII characters A to Z | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | <br />  | ||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 20px; padding-bottom: 15px;"> | ||
| + | <div style="font-size: 14px; padding-left: 12px;">'''Keymap index''' <code> KEYMAP_INDEX_* </code></div> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>KEYMAP_INDEX_NORMAL = 0;</code> | ||
| + | | Normal (unshifted) value | ||
| + | |- | ||
| + | | <code>KEYMAP_INDEX_SHIFT = 1;</code> | ||
| + | | Shifted value | ||
| + | |- | ||
| + | | <code>KEYMAP_INDEX_ALTGR = 2;</code> | ||
| + | | AltGr value | ||
| + | |- | ||
| + | | <code>KEYMAP_INDEX_SHIFT_ALTGR = 3;</code> | ||
| + | | Shift plus AltGr value | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | <br />  | ||
| === Type definitions === | === Type definitions === | ||
| ---- | ---- | ||
| − | '' | + | |
| + | '''Keymap header''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapHeader = ^TKeymapHeader;</code> | ||
| + | |||
| + | <code>TKeymapHeader = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>Mode:LongWord;</code> | ||
| + | | Keymap mode (eg KEYMAP_MODE_NONE) | ||
| + | |- | ||
| + | | <code>Flags:LongWord;</code> | ||
| + | | Keymap flags (eg KEYMAP_FLAG_ALTGR) | ||
| + | |- | ||
| + | | <code>KeyCount:LongWord;</code> | ||
| + | | Number of keys in keymap (Default: KEYMAP_KEY_COUNT) | ||
| + | |- | ||
| + | | <code>RowCount:LongWord;</code> | ||
| + | | Number of index rows in keymap (Default: KEYMAP_ROW_COUNT) | ||
| + | |- | ||
| + | | <code>Name:String[255];</code> | ||
| + | | Keymap name | ||
| + | |- | ||
| + | | <code>Description:String[255];</code> | ||
| + | | Keymap description | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>  | ||
| + | |||
| + | '''Keymap data''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapData = ^TKeymapData;</code> | ||
| + | |||
| + | <code>TKeymapData = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>Data:array[0..255,KEYMAP_INDEX_NORMAL..KEYMAP_INDEX_SHIFT_ALTGR] of Word;</code> | ||
| + | | Key mapping data, 4 words for Normal, Shift, AltGr, Shift+AltGr for each of the 256 keys (See KEY_CODE_* constants) | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>  | ||
| + | |||
| + | '''Keymap chars''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapChars = ^TKeymapChars;</code> | ||
| + | |||
| + | <code>TKeymapChars = array[0..0] of Word;</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | |   | ||
| + | | style="width: 50%;"|  | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>  | ||
| + | |||
| + | '''Keymap capskey'''  | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapCapskey = ^TKeymapCapskey;</code> | ||
| + | |||
| + | <code>TKeymapCapskey = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | |colspan="2"|Note: Keymap Capskey (Keys affected by the Caps Lock function) | ||
| + | |- | ||
| + | | <code>First:Word;</code> | ||
| + | | First key in caps key range (SCAN_CODE_* value) | ||
| + | |- | ||
| + | | <code>Last:Word;</code> | ||
| + | | Last key in caps key range (SCAN_CODE_* value)(Make first and last the same for a single key) | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>  | ||
| + | |||
| + | '''Keymap capskeys''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapCapskeys = ^TKeymapCapskeys;</code> | ||
| + | |||
| + | <code>TKeymapCapskeys = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>Count:LongWord;</code> | ||
| + | | style="width: 50%;"|  | ||
| + | |- | ||
| + | | <code>Keys:array[0..KEYMAP_MAX_CAPSKEYS - 1] of TKeymapCapskey;</code> | ||
| + | |   | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | |||
| + | '''Keymap resolve''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapResolve = ^TKeymapResolve;</code> | ||
| + | |||
| + | <code>TKeymapResolve = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>Key:Word;</code> | ||
| + | | The scan code of the key pressed after the deadkey (SCAN_CODE_* value) | ||
| + | |- | ||
| + | | <code>Index:Byte;</code> | ||
| + | | The index state of the key pressed after the deadkey (eg KEYMAP_INDEX_NORMAL) | ||
| + | |- | ||
| + | | <code>Code:Word;</code> | ||
| + | | The key code of the resulting character (KEY_CODE_* value) | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>  | ||
| + | |||
| + | '''Keymap deadkey'''  | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapDeadkey = ^TKeymapDeadkey;</code> | ||
| + | |||
| + | <code>TKeymapDeadkey = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | |colspan="2"|Note: Keymap Deadkey (Keys which behave as dead keys) | ||
| + | |- | ||
| + | | <code>Key:Word;</code> | ||
| + | | The scan code of the key which behaves as a deadkey (SCAN_CODE_* value) | ||
| + | |- | ||
| + | | <code>Index:Byte;</code> | ||
| + | | The index state in which the key behaves as a deadkey (eg KEYMAP_INDEX_NORMAL) | ||
| + | |- | ||
| + | | <code>Resolves:array[0..KEYMAP_MAX_RESOLVES - 1] of TKeymapResolve;</code> | ||
| + | |   | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>   | ||
| + | |||
| + | '''Keymap deadkeys''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapDeadkeys = ^TKeymapDeadkeys;</code> | ||
| + | |||
| + | <code>TKeymapDeadkeys = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>Count:LongWord;</code> | ||
| + | | style="width: 50%;"|  | ||
| + | |- | ||
| + | | <code>Keys:array[0..KEYMAP_MAX_DEADKEYS - 1] of TKeymapDeadkey;</code> | ||
| + | |   | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>   | ||
| + | |||
| + | '''Keymap properties''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapProperties = ^TKeymapProperties;</code> | ||
| + | |||
| + | <code>TKeymapProperties = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | | <code>KeymapMode:LongWord;</code> | ||
| + | | Keymap mode (eg KEYMAP_MODE_NONE) | ||
| + | |- | ||
| + | | <code>KeymapFlags:LongWord;</code> | ||
| + | | Keymap flags (eg KEYMAP_FLAG_ALTGR) | ||
| + | |- | ||
| + | | <code>KeyCount:LongWord;</code> | ||
| + | | Number of keys in keymap (Default: KEYMAP_KEY_COUNT) | ||
| + | |- | ||
| + | | <code>RowCount:LongWord;</code> | ||
| + | | Number of index rows in keymap (Default: KEYMAP_ROW_COUNT) | ||
| + | |- | ||
| + | | <code>KeymapName:array[0..KEYMAP_NAME_LENGTH - 1] of Char;</code> | ||
| + | | Keymap name | ||
| + | |- | ||
| + | | <code>KeymapDescription:array[0..KEYMAP_DESC_LENGTH - 1] of Char;</code> | ||
| + | | Keymap description | ||
| + | |- | ||
| + | |} | ||
| + | </div></div> | ||
| + | |||
| + | '''Keymap enumeration callback''' | ||
| + | |||
| + | {| class="wikitable" style="font-size: 14px; text-align: left; width: 100%; height: 50px;" | ||
| + | |- | ||
| + | | <code>TKeymapEnumerate = function(Handle:TKeymapHandle; Data:Pointer):LongWord;</code> | ||
| + | | style="width: 40%;"| | ||
| + | |- | ||
| + | |}  | ||
| + | |||
| + | '''Keymap entry''' | ||
| + | |||
| + | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial;"> | ||
| + | <code>PKeymapEntry = ^TKeymapEntry;</code> | ||
| + | |||
| + | <code>TKeymapEntry = record</code> | ||
| + | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| + | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| + | |- | ||
| + | |colspan="2"|''Keymap Properties'' | ||
| + | |- | ||
| + | | <code>Signature:LongWord;</code> | ||
| + | | Signature for entry validation | ||
| + | |- | ||
| + | | <code>KeymapMode:LongWord;</code> | ||
| + | | Keymap mode (eg KEYMAP_MODE_NONE) | ||
| + | |- | ||
| + | | <code>KeymapFlags:LongWord;</code> | ||
| + | | Keymap flags (eg KEYMAP_FLAG_ALTGR) | ||
| + | |- | ||
| + | | <code>KeymapName:array[0..KEYMAP_NAME_LENGTH - 1] of Char;</code> | ||
| + | | Keymap name | ||
| + | |- | ||
| + | | <code>KeymapDescription:array[0..KEYMAP_DESC_LENGTH - 1] of Char;</code> | ||
| + | | Keymap description | ||
| + | |- | ||
| + | |colspan="2"|''Driver Properties'' | ||
| + | |- | ||
| + | | <code>KeyData:Pointer;</code> | ||
| + | | Keymap key data | ||
| + | |- | ||
| + | | <code>KeyCount:LongWord;</code> | ||
| + | | Number of keys in key data (Default: KEYMAP_KEY_COUNT) | ||
| + | |- | ||
| + | | <code>RowCount:LongWord;</code> | ||
| + | | Number of index rows in key data (Default: KEYMAP_ROW_COUNT) | ||
| + | |- | ||
| + | | <code>CapskeysData:PKeymapCapskeys;</code> | ||
| + | | Keymap Capskeys data (Keys affected by Caps Lock) | ||
| + | |- | ||
| + | | <code>DeadkeysData:PKeymapDeadkeys;</code> | ||
| + | | Keymap Deadkeys data (Keys which behave as Dead keys) | ||
| + | |- | ||
| + | |colspan="2"|''Internal Properties'' | ||
| + | |- | ||
| + | | <code>Prev:PKeymapEntry;</code> | ||
| + | | Previous entry in Keymap table | ||
| + | |- | ||
| + | | <code>Next:PKeymapEntry;</code> | ||
| + | | Next entry in Keymap table | ||
| + | |- | ||
| + | |} | ||
| + | </div></div>   | ||
| + | <br /> | ||
| === Public variables === | === Public variables === | ||
| ---- | ---- | ||
| − | '' | + | ''None defined'' | 
| === Function declarations === | === Function declarations === | ||
| Line 72: | Line 431: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Note | 
| | Called only during system startup | | Called only during system startup | ||
| |- | |- | ||
| Line 87: | Line 446: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Header | 
| | Pointer to the keymap header | | Pointer to the keymap header | ||
| |- | |- | ||
| − | !  | + | ! Data | 
| | Pointer to the keymap data | | Pointer to the keymap data | ||
| |- | |- | ||
| − | !  | + | ! Size | 
| | Size of the keymap data | | Size of the keymap data | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | Handle of the newly loaded keymap or INVALID_HANDLE_VALUE on failure | | Handle of the newly loaded keymap or INVALID_HANDLE_VALUE on failure | ||
| |- | |- | ||
| Line 108: | Line 467: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Header | 
| | Pointer to the keymap header (See TKeymapHeader) | | Pointer to the keymap header (See TKeymapHeader) | ||
| |- | |- | ||
| − | !  | + | ! Data | 
| | Pointer to the keymap data (See TKeymapData) | | Pointer to the keymap data (See TKeymapData) | ||
| |- | |- | ||
| − | !  | + | ! Capskeys | 
| | Pointer to the capskeys table (Optional) | | Pointer to the capskeys table (Optional) | ||
| |- | |- | ||
| − | !  | + | ! Deadkeys | 
| | Pointer to the deadkeys table (Optional) | | Pointer to the deadkeys table (Optional) | ||
| |- | |- | ||
| − | !  | + | ! Size | 
| | Size of the keymap data | | Size of the keymap data | ||
| |- | |- | ||
| − | !  | + | ! Properties | 
| | Pointer to a keymap properties record to use instead of the header (Optional) | | Pointer to a keymap properties record to use instead of the header (Optional) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | Handle of the newly loaded keymap or INVALID_HANDLE_VALUE on failure | | Handle of the newly loaded keymap or INVALID_HANDLE_VALUE on failure | ||
| |- | |- | ||
| Line 138: | Line 497: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to unload | | The handle of the keymap to unload | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | ERROR_SUCCESS if completed or another error code on failure | | ERROR_SUCCESS if completed or another error code on failure | ||
| |- | |- | ||
| Line 153: | Line 512: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to get the name for | | The handle of the keymap to get the name for | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | The name of the keymap (eg US) | | The name of the keymap (eg US) | ||
| |- | |- | ||
| Line 168: | Line 527: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to get the description for | | The handle of the keymap to get the description for | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | The description of the keymap (eg US English) | | The description of the keymap (eg US English) | ||
| |- | |- | ||
| Line 183: | Line 542: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to check the flag for | | The handle of the keymap to check the flag for | ||
| |- | |- | ||
| − | !  | + | ! Flag | 
| | The flag value to check (eg KEYMAP_FLAG_CAPS_ASCII) | | The flag value to check (eg KEYMAP_FLAG_CAPS_ASCII) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | True if the flag is set and False if not set | | True if the flag is set and False if not set | ||
| |- | |- | ||
| Line 201: | Line 560: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to use for translation | | The handle of the keymap to use for translation | ||
| |- | |- | ||
| − | !  | + | ! ScanCode | 
| | The keyboard scan code value to resolve (eg SCAN_CODE_A) | | The keyboard scan code value to resolve (eg SCAN_CODE_A) | ||
| |- | |- | ||
| − | !  | + | ! Index | 
| | The keymap index to use for the translation (eg KEYMAP_INDEX_SHIFT) | | The keymap index to use for the translation (eg KEYMAP_INDEX_SHIFT) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | The translated key code value (eg KEY_CODE_A) or KEY_CODE_NONE on failure | | The translated key code value (eg KEY_CODE_A) or KEY_CODE_NONE on failure | ||
| |- | |- | ||
| Line 222: | Line 581: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to use for translation | | The handle of the keymap to use for translation | ||
| |- | |- | ||
| − | !  | + | ! KeyCode | 
| | The key code value to resolve (eg KEY_CODE_A) | | The key code value to resolve (eg KEY_CODE_A) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | The ANSI character value for the keycode or 0 on failure | | The ANSI character value for the keycode or 0 on failure | ||
| |- | |- | ||
| Line 240: | Line 599: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to use for translation | | The handle of the keymap to use for translation | ||
| |- | |- | ||
| − | !  | + | ! KeyCode | 
| | The key code value to resolve (eg KEY_CODE_A) | | The key code value to resolve (eg KEY_CODE_A) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | The Unicode character value for the keycode or 0 on failure | | The Unicode character value for the keycode or 0 on failure | ||
| |- | |- | ||
| Line 258: | Line 617: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to check | | The handle of the keymap to check | ||
| |- | |- | ||
| − | !  | + | ! ScanCode | 
| | The scan code value to check (eg SCAN_CODE_A) | | The scan code value to check (eg SCAN_CODE_A) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | True if affected by Caps Lock, False if not | | True if affected by Caps Lock, False if not | ||
| |- | |- | ||
| Line 276: | Line 635: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to check | | The handle of the keymap to check | ||
| |- | |- | ||
| − | !  | + | ! ScanCode | 
| | The scan code value to check (eg SCAN_CODE_A) | | The scan code value to check (eg SCAN_CODE_A) | ||
| |- | |- | ||
| − | !  | + | ! Index | 
| | The keymap index to check (eg KEYMAP_INDEX_SHIFT) | | The keymap index to check (eg KEYMAP_INDEX_SHIFT) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | True if the scan key is a Dead Key, False if not | | True if the scan key is a Dead Key, False if not | ||
| |- | |- | ||
| Line 297: | Line 656: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to use for resolution | | The handle of the keymap to use for resolution | ||
| |- | |- | ||
| − | !  | + | ! DeadCode | 
| | The scan code value of the dead key (eg SCAN_CODE_GRAVE) | | The scan code value of the dead key (eg SCAN_CODE_GRAVE) | ||
| |- | |- | ||
| − | !  | + | ! ScanCode | 
| | The scan code value of the next key (eg (SCAN_CODE_A) | | The scan code value of the next key (eg (SCAN_CODE_A) | ||
| |- | |- | ||
| − | !  | + | ! DeadIndex | 
| | The keymap index of the dead key (eg KEYMAP_INDEX_SHIFT) | | The keymap index of the dead key (eg KEYMAP_INDEX_SHIFT) | ||
| |- | |- | ||
| − | !  | + | ! ScanIndex | 
| | The keymap index of the next key (eg KEYMAP_INDEX_SHIFT) | | The keymap index of the next key (eg KEYMAP_INDEX_SHIFT) | ||
| |- | |- | ||
| − | !  | + | ! KeyCode | 
| − | | Return value for the key code represented by the dead key / next key combination (or KEY_CODE_NONE) | + | | Return value for the key code represented by the dead key/next key combination (or KEY_CODE_NONE) | 
| |- | |- | ||
| − | !  | + | ! Return | 
| − | | True if the dead key / next key combination resolves to a key code or False if not | + | | True if the dead key/next key combination resolves to a key code or False if not | 
| |- | |- | ||
| |} | |} | ||
| Line 327: | Line 686: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Handle | 
| | The handle of the keymap to get the properties for | | The handle of the keymap to get the properties for | ||
| |- | |- | ||
| − | !  | + | ! Properties | 
| | Pointer to a keymap properties structure to return the properties | | Pointer to a keymap properties structure to return the properties | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | ERROR_SUCCESS if completed or another error code on failure | | ERROR_SUCCESS if completed or another error code on failure | ||
| |- | |- | ||
| Line 345: | Line 704: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Name | 
| | The name of the keymap to find (eg US) | | The name of the keymap to find (eg US) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | The handle of the matching keymap or INVALID_HANDLE_VALUE if not found | | The handle of the matching keymap or INVALID_HANDLE_VALUE if not found | ||
| |- | |- | ||
| Line 360: | Line 719: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Description | 
| | The description of the keymap to find (eg US English) | | The description of the keymap to find (eg US English) | ||
| |- | |- | ||
| − | !  | + | ! Return | 
| | The handle of the matching keymap or INVALID_HANDLE_VALUE if not found | | The handle of the matching keymap or INVALID_HANDLE_VALUE if not found | ||
| |- | |- | ||
| Line 375: | Line 734: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Callback | 
| | The function to call for each loaded keymap | | The function to call for each loaded keymap | ||
| |- | |- | ||
| − | !  | + | ! Data | 
| | A private data pointer to pass to callback for each loaded keymap | | A private data pointer to pass to callback for each loaded keymap | ||
| |- | |- | ||
| Line 388: | Line 747: | ||
| <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 0px; padding-bottom: 15px;"> | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 0px; padding-bottom: 15px;"> | ||
| − | <pre style="border: 0; padding-bottom:0px;">function KeymapGetCount:LongWord | + | <pre style="border: 0; padding-bottom:0px;">function KeymapGetCount:LongWord;</pre> | 
| <div style="font-size: 14px; padding-left: 12px;">'''Description:''' Get the current keymap count</div> | <div style="font-size: 14px; padding-left: 12px;">'''Description:''' Get the current keymap count</div> | ||
| <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Note | 
| − | |  | + | | None documented | 
| |- | |- | ||
| |} | |} | ||
| Line 400: | Line 759: | ||
| <br /> | <br /> | ||
| <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 0px; padding-bottom: 15px;"> | <div class="toccolours mw-collapsible mw-collapsed" style="border: 1; font-family: arial; padding-top: 0px; padding-bottom: 15px;"> | ||
| − | <pre style="border: 0; padding-bottom:0px;">function KeymapGetDefault:TKeymapHandle | + | <pre style="border: 0; padding-bottom:0px;">function KeymapGetDefault:TKeymapHandle;</pre> | 
| <div style="font-size: 14px; padding-left: 12px;">'''Description:''' Get the current default keymap</div> | <div style="font-size: 14px; padding-left: 12px;">'''Description:''' Get the current default keymap</div> | ||
| <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | <div class="mw-collapsible-content" style="text-align: left; padding-left: 5px;"> | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Note | 
| − | |  | + | | None documented | 
| |- | |- | ||
| |} | |} | ||
| Line 417: | Line 776: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Note | 
| − | |  | + | | None documented | 
| |- | |- | ||
| |} | |} | ||
| Line 429: | Line 788: | ||
| {| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
| |- | |- | ||
| − | !  | + | ! Note | 
| − | |  | + | | None documented | 
| |- | |- | ||
| |} | |} | ||
Latest revision as of 04:36, 12 September 2023
Return to Unit Reference
Description
Ultibo Keymap Interface unit
Keymaps
Keymaps define the translation of a keyboard scan code (the SCAN_CODE_* values) to a key code value (the KEY_CODE_* values) and provide the ability to handle different keyboard layouts in different countries and regions.
The keyboard scan codes are based on the values in Section 10 of the Universal Serial Bus HID Usage Tables v1.12 and are the actual values returned by the keyboard when a key is pressed.
The key code values are based on the Unicode standard with each key code mapped to the code point for that character.
This allows almost infinite flexibility in the way keyboard scan codes are mapped to actual characters and avoids the need to make unreliable assumptions about ASCII characters and upper or lower case handling.
Since the output of the keyboard is a stream of TKeyboardData structures containing both the scan code and the key code then higher level functions can retranslate the data in any way required.
Caps Keys
Caps keys account for the set of keys which are affected by Caps Lock in any given keyboard layout.
In some layouts only the alphabetic keys are affected, in other layouts some or all of the numeric and punctuation keys are also affected.
The caps keys data for any keyboard layout allows defining ranges of keys that are affected by the Caps Lock state.
Dead Keys
Dead keys account for the set of keys which behave as dead keys in any given keyboard layout.
On pressing a deadkey it will be recognized by the keyboard as such and stored until the next key press occurs. If the next keypress is one of the resolves for the pressed dead key then the output character will be the key code value of the resolve not for the key itself.
If the next keypress after a dead key is not one of the resolves that the dead key and the pressed key will both be output to the keyboard buffer.
Setting the default keymap for the system
Additional keymaps are provided as units which can be included in a program and will auto load themselves if included.
All keymap units are configured to check for both the environment variable KEYMAP_DEFAULT and the global configuration variable KEYMAP_DEFAULT to determine if either of them is set to the name of that keymap. If either is set to the keymap name then that keymap will also set itself as the default during system startup.
The environment variable KEYMAP_DEFAULT can be set by adding KEYMAP_DEFAULT=XX (where XX is the name of the keymap, eg DE for Keymap_DE) to the command line of the application (dependent on the system, for a Raspberry Pi use the cmdline.txt file on the SD card).
The global configuration variable KEYMAP_DEFAULT can be set in code by including the GlobalConfig unit in a program and setting the variable during startup.
At any time after startup the default keymap can be changed by call the KeymapSetDefault function.
Constants
 KEYMAP_* | KEYMAP_KEY_COUNT = 256; | Number of key mappings in a keymap entry | 
| KEYMAP_ROW_COUNT = 4; | Number of mapping rows per key in a keymap entry (Normal, Shift, AltGr, Shift_AltGr) | 
| KEYMAP_ROW_SIZE = SizeOf(Word); | |
| KEYMAP_MAX_CAPSKEYS = 50; | Maximum number of keys that can be listed in the TKeymapCapskeys structure | 
| KEYMAP_MAX_DEADKEYS = 5; | Maximum number of keys that can be listed in the TKeymapDeadkeys structure | 
| KEYMAP_MAX_RESOLVES = 20; | Maximum number of resolves that can be listed in the TKeymapDeadkey structure | 
 
 KEYMAP_SIGNATURE_* | KEYMAP_SIGNATURE = $863FDBA1; | 
 KEYMAP_*_LENGTH | KEYMAP_NAME_LENGTH = SIZE_64; | Length of keymap name | 
| KEYMAP_DESC_LENGTH = SIZE_128; | Length of keymap description | 
 
 KEYMAP_MODE_* | KEYMAP_MODE_NONE = 0; | 
 
 KEYMAP_FLAG_* | KEYMAP_FLAG_NONE = $00000000; | |
| KEYMAP_FLAG_ALTGR = $00000001; | The key mapping uses the AltGr key | 
| KEYMAP_FLAG_CAPS_ALL = $00000002; | Caps Lock shifts all characters not just alphabetic | 
| KEYMAP_FLAG_CAPS_ASCII = $00000004; | Caps Lock shifts only ASCII characters A to Z | 
 
 KEYMAP_INDEX_* | KEYMAP_INDEX_NORMAL = 0; | Normal (unshifted) value | 
| KEYMAP_INDEX_SHIFT = 1; | Shifted value | 
| KEYMAP_INDEX_ALTGR = 2; | AltGr value | 
| KEYMAP_INDEX_SHIFT_ALTGR = 3; | Shift plus AltGr value | 
 
Type definitions
Keymap header
PKeymapHeader = ^TKeymapHeader;
TKeymapHeader = record
| Mode:LongWord; | Keymap mode (eg KEYMAP_MODE_NONE) | 
| Flags:LongWord; | Keymap flags (eg KEYMAP_FLAG_ALTGR) | 
| KeyCount:LongWord; | Number of keys in keymap (Default: KEYMAP_KEY_COUNT) | 
| RowCount:LongWord; | Number of index rows in keymap (Default: KEYMAP_ROW_COUNT) | 
| Name:String[255]; | Keymap name | 
| Description:String[255]; | Keymap description | 
Keymap data
PKeymapData = ^TKeymapData;
TKeymapData = record
| Data:array[0..255,KEYMAP_INDEX_NORMAL..KEYMAP_INDEX_SHIFT_ALTGR] of Word; | Key mapping data, 4 words for Normal, Shift, AltGr, Shift+AltGr for each of the 256 keys (See KEY_CODE_* constants) | 
Keymap chars
PKeymapChars = ^TKeymapChars;
TKeymapChars = array[0..0] of Word;
Keymap capskey
PKeymapCapskey = ^TKeymapCapskey;
TKeymapCapskey = record
| Note: Keymap Capskey (Keys affected by the Caps Lock function) | |
| First:Word; | First key in caps key range (SCAN_CODE_* value) | 
| Last:Word; | Last key in caps key range (SCAN_CODE_* value)(Make first and last the same for a single key) | 
Keymap capskeys
PKeymapCapskeys = ^TKeymapCapskeys;
TKeymapCapskeys = record
| Count:LongWord; | |
| Keys:array[0..KEYMAP_MAX_CAPSKEYS - 1] of TKeymapCapskey; | 
Keymap resolve
PKeymapResolve = ^TKeymapResolve;
TKeymapResolve = record
| Key:Word; | The scan code of the key pressed after the deadkey (SCAN_CODE_* value) | 
| Index:Byte; | The index state of the key pressed after the deadkey (eg KEYMAP_INDEX_NORMAL) | 
| Code:Word; | The key code of the resulting character (KEY_CODE_* value) | 
Keymap deadkey
PKeymapDeadkey = ^TKeymapDeadkey;
TKeymapDeadkey = record
| Note: Keymap Deadkey (Keys which behave as dead keys) | |
| Key:Word; | The scan code of the key which behaves as a deadkey (SCAN_CODE_* value) | 
| Index:Byte; | The index state in which the key behaves as a deadkey (eg KEYMAP_INDEX_NORMAL) | 
| Resolves:array[0..KEYMAP_MAX_RESOLVES - 1] of TKeymapResolve; | |
Keymap deadkeys
PKeymapDeadkeys = ^TKeymapDeadkeys;
TKeymapDeadkeys = record
| Count:LongWord; | |
| Keys:array[0..KEYMAP_MAX_DEADKEYS - 1] of TKeymapDeadkey; | 
Keymap properties
PKeymapProperties = ^TKeymapProperties;
TKeymapProperties = record
| KeymapMode:LongWord; | Keymap mode (eg KEYMAP_MODE_NONE) | 
| KeymapFlags:LongWord; | Keymap flags (eg KEYMAP_FLAG_ALTGR) | 
| KeyCount:LongWord; | Number of keys in keymap (Default: KEYMAP_KEY_COUNT) | 
| RowCount:LongWord; | Number of index rows in keymap (Default: KEYMAP_ROW_COUNT) | 
| KeymapName:array[0..KEYMAP_NAME_LENGTH - 1] of Char; | Keymap name | 
| KeymapDescription:array[0..KEYMAP_DESC_LENGTH - 1] of Char; | Keymap description | 
Keymap enumeration callback
| TKeymapEnumerate = function(Handle:TKeymapHandle; Data:Pointer):LongWord; | 
Keymap entry
PKeymapEntry = ^TKeymapEntry;
TKeymapEntry = record
| Keymap Properties | |
| Signature:LongWord; | Signature for entry validation | 
| KeymapMode:LongWord; | Keymap mode (eg KEYMAP_MODE_NONE) | 
| KeymapFlags:LongWord; | Keymap flags (eg KEYMAP_FLAG_ALTGR) | 
| KeymapName:array[0..KEYMAP_NAME_LENGTH - 1] of Char; | Keymap name | 
| KeymapDescription:array[0..KEYMAP_DESC_LENGTH - 1] of Char; | Keymap description | 
| Driver Properties | |
| KeyData:Pointer; | Keymap key data | 
| KeyCount:LongWord; | Number of keys in key data (Default: KEYMAP_KEY_COUNT) | 
| RowCount:LongWord; | Number of index rows in key data (Default: KEYMAP_ROW_COUNT) | 
| CapskeysData:PKeymapCapskeys; | Keymap Capskeys data (Keys affected by Caps Lock) | 
| DeadkeysData:PKeymapDeadkeys; | Keymap Deadkeys data (Keys which behave as Dead keys) | 
| Internal Properties | |
| Prev:PKeymapEntry; | Previous entry in Keymap table | 
| Next:PKeymapEntry; | Next entry in Keymap table | 
Public variables
None defined
Function declarations
Initialization functions
procedure KeymapInit;
| Note | Called only during system startup | 
|---|
Keymap functions
function KeymapLoad(Header:PKeymapHeader; Data:PKeymapData; Size:LongWord):TKeymapHandle;
| Header | Pointer to the keymap header | 
|---|---|
| Data | Pointer to the keymap data | 
| Size | Size of the keymap data | 
| Return | Handle of the newly loaded keymap or INVALID_HANDLE_VALUE on failure | 
function KeymapLoadEx(Header:PKeymapHeader; Data:PKeymapData; Capskeys:PKeymapCapskeys; Deadkeys:PKeymapDeadkeys; Size:LongWord; Properties:PKeymapProperties):TKeymapHandle;
| Header | Pointer to the keymap header (See TKeymapHeader) | 
|---|---|
| Data | Pointer to the keymap data (See TKeymapData) | 
| Capskeys | Pointer to the capskeys table (Optional) | 
| Deadkeys | Pointer to the deadkeys table (Optional) | 
| Size | Size of the keymap data | 
| Properties | Pointer to a keymap properties record to use instead of the header (Optional) | 
| Return | Handle of the newly loaded keymap or INVALID_HANDLE_VALUE on failure | 
function KeymapUnload(Handle:TKeymapHandle):LongWord;
| Handle | The handle of the keymap to unload | 
|---|---|
| Return | ERROR_SUCCESS if completed or another error code on failure | 
function KeymapGetName(Handle:TKeymapHandle):String;
| Handle | The handle of the keymap to get the name for | 
|---|---|
| Return | The name of the keymap (eg US) | 
function KeymapGetDescription(Handle:TKeymapHandle):String;
| Handle | The handle of the keymap to get the description for | 
|---|---|
| Return | The description of the keymap (eg US English) | 
function KeymapCheckFlag(Handle:TKeymapHandle; Flag:LongWord):Boolean;
| Handle | The handle of the keymap to check the flag for | 
|---|---|
| Flag | The flag value to check (eg KEYMAP_FLAG_CAPS_ASCII) | 
| Return | True if the flag is set and False if not set | 
function KeymapGetKeyCode(Handle:TKeymapHandle; ScanCode:Word; Index:Byte):Word;
| Handle | The handle of the keymap to use for translation | 
|---|---|
| ScanCode | The keyboard scan code value to resolve (eg SCAN_CODE_A) | 
| Index | The keymap index to use for the translation (eg KEYMAP_INDEX_SHIFT) | 
| Return | The translated key code value (eg KEY_CODE_A) or KEY_CODE_NONE on failure | 
function KeymapGetCharCode(Handle:TKeymapHandle; KeyCode:Word):Char;
| Handle | The handle of the keymap to use for translation | 
|---|---|
| KeyCode | The key code value to resolve (eg KEY_CODE_A) | 
| Return | The ANSI character value for the keycode or 0 on failure | 
function KeymapGetCharUnicode(Handle:TKeymapHandle; KeyCode:Word):WideChar;
| Handle | The handle of the keymap to use for translation | 
|---|---|
| KeyCode | The key code value to resolve (eg KEY_CODE_A) | 
| Return | The Unicode character value for the keycode or 0 on failure | 
function KeymapCheckCapskey(Handle:TKeymapHandle; ScanCode:Word):Boolean;
| Handle | The handle of the keymap to check | 
|---|---|
| ScanCode | The scan code value to check (eg SCAN_CODE_A) | 
| Return | True if affected by Caps Lock, False if not | 
function KeymapCheckDeadkey(Handle:TKeymapHandle; ScanCode:Word; Index:Byte):Boolean;
| Handle | The handle of the keymap to check | 
|---|---|
| ScanCode | The scan code value to check (eg SCAN_CODE_A) | 
| Index | The keymap index to check (eg KEYMAP_INDEX_SHIFT) | 
| Return | True if the scan key is a Dead Key, False if not | 
function KeymapResolveDeadkey(Handle:TKeymapHandle; DeadCode,ScanCode:Word; DeadIndex,ScanIndex:Byte; var KeyCode:Word):Boolean;
| Handle | The handle of the keymap to use for resolution | 
|---|---|
| DeadCode | The scan code value of the dead key (eg SCAN_CODE_GRAVE) | 
| ScanCode | The scan code value of the next key (eg (SCAN_CODE_A) | 
| DeadIndex | The keymap index of the dead key (eg KEYMAP_INDEX_SHIFT) | 
| ScanIndex | The keymap index of the next key (eg KEYMAP_INDEX_SHIFT) | 
| KeyCode | Return value for the key code represented by the dead key/next key combination (or KEY_CODE_NONE) | 
| Return | True if the dead key/next key combination resolves to a key code or False if not | 
function KeymapGetProperties(Handle:TKeymapHandle; Properties:PKeymapProperties):LongWord;
| Handle | The handle of the keymap to get the properties for | 
|---|---|
| Properties | Pointer to a keymap properties structure to return the properties | 
| Return | ERROR_SUCCESS if completed or another error code on failure | 
function KeymapFindByName(const Name:String):TKeymapHandle;
| Name | The name of the keymap to find (eg US) | 
|---|---|
| Return | The handle of the matching keymap or INVALID_HANDLE_VALUE if not found | 
function KeymapFindByDescription(const Description:String):TKeymapHandle;
| Description | The description of the keymap to find (eg US English) | 
|---|---|
| Return | The handle of the matching keymap or INVALID_HANDLE_VALUE if not found | 
function KeymapEnumerate(Callback:TKeymapEnumerate; Data:Pointer):LongWord;
| Callback | The function to call for each loaded keymap | 
|---|---|
| Data | A private data pointer to pass to callback for each loaded keymap | 
Keymap helper functions
function KeymapGetCount:LongWord;
| Note | None documented | 
|---|
function KeymapGetDefault:TKeymapHandle;
| Note | None documented | 
|---|
function KeymapSetDefault(Handle:TKeymapHandle):LongWord;
| Note | None documented | 
|---|
function KeymapCheck(Keymap:PKeymapEntry):PKeymapEntry;
| Note | None documented | 
|---|
Return to Unit Reference

