Где я могу найти список кодов виртуальных клавиш Mac?

Я использую CGEventCreateKeyboardEvent и нужно знать что CGKeyCode значения для использования.

В частности, я после кода клавиши для клавиши Command. В документах приведены примеры для других ключей: z is 6сдвиг 56,

Где-то должен быть список виртуальных кодов клавиш Mac?

8 ответов

Решение

Более каноническая ссылка в <HIToolbox/Events.h>:

/System/Library/Frameworks/Carbon.framework/Versions/A/Frameworks/HIToolbox.framework/Versions/A/Headers/Events.h

Ниже приведен список общих кодов клавиш для быстрого ознакомления, взятый из Events.h,

Если вам нужно использовать эти ключевые коды в приложении, вы должны включить Carbon framework:

Objective-C:
#include <Carbon/Carbon.h>

Swift:
import Carbon.HIToolbox

Затем вы можете использовать kVK_ANSI_A константы напрямую.


ПРЕДУПРЕЖДЕНИЕ

Константы клавиш ссылаются на физические клавиши на клавиатуре. Их вывод изменяется, если машинистка использует другую раскладку клавиатуры. Буквы в константах соответствуют только раскладке клавиатуры США QWERTY.

Например, левая безымянная клавиша на гомерове:

QWERTY keyboard layout > s > kVK_ANSI_S > "s"
Dvorak keyboard layout > о > kVK_ANSI_S > "o"

Стратегии преобразования макроса кода в строку, не зависящего от компоновки, и наоборот, обсуждаются здесь:

Как преобразовать символ ASCII в CGKeyCode?


От Events.h:

/*
 *  Summary:
 *    Virtual keycodes
 *  
 *  Discussion:
 *    These constants are the virtual keycodes defined originally in
 *    Inside Mac Volume V, pg. V-191. They identify physical keys on a
 *    keyboard. Those constants with "ANSI" in the name are labeled
 *    according to the key position on an ANSI-standard US keyboard.
 *    For example, kVK_ANSI_A indicates the virtual keycode for the key
 *    with the letter 'A' in the US keyboard layout. Other keyboard
 *    layouts may have the 'A' key label on a different physical key;
 *    in this case, pressing 'A' will generate a different virtual
 *    keycode.
 */
enum {
  kVK_ANSI_A                    = 0x00,
  kVK_ANSI_S                    = 0x01,
  kVK_ANSI_D                    = 0x02,
  kVK_ANSI_F                    = 0x03,
  kVK_ANSI_H                    = 0x04,
  kVK_ANSI_G                    = 0x05,
  kVK_ANSI_Z                    = 0x06,
  kVK_ANSI_X                    = 0x07,
  kVK_ANSI_C                    = 0x08,
  kVK_ANSI_V                    = 0x09,
  kVK_ANSI_B                    = 0x0B,
  kVK_ANSI_Q                    = 0x0C,
  kVK_ANSI_W                    = 0x0D,
  kVK_ANSI_E                    = 0x0E,
  kVK_ANSI_R                    = 0x0F,
  kVK_ANSI_Y                    = 0x10,
  kVK_ANSI_T                    = 0x11,
  kVK_ANSI_1                    = 0x12,
  kVK_ANSI_2                    = 0x13,
  kVK_ANSI_3                    = 0x14,
  kVK_ANSI_4                    = 0x15,
  kVK_ANSI_6                    = 0x16,
  kVK_ANSI_5                    = 0x17,
  kVK_ANSI_Equal                = 0x18,
  kVK_ANSI_9                    = 0x19,
  kVK_ANSI_7                    = 0x1A,
  kVK_ANSI_Minus                = 0x1B,
  kVK_ANSI_8                    = 0x1C,
  kVK_ANSI_0                    = 0x1D,
  kVK_ANSI_RightBracket         = 0x1E,
  kVK_ANSI_O                    = 0x1F,
  kVK_ANSI_U                    = 0x20,
  kVK_ANSI_LeftBracket          = 0x21,
  kVK_ANSI_I                    = 0x22,
  kVK_ANSI_P                    = 0x23,
  kVK_ANSI_L                    = 0x25,
  kVK_ANSI_J                    = 0x26,
  kVK_ANSI_Quote                = 0x27,
  kVK_ANSI_K                    = 0x28,
  kVK_ANSI_Semicolon            = 0x29,
  kVK_ANSI_Backslash            = 0x2A,
  kVK_ANSI_Comma                = 0x2B,
  kVK_ANSI_Slash                = 0x2C,
  kVK_ANSI_N                    = 0x2D,
  kVK_ANSI_M                    = 0x2E,
  kVK_ANSI_Period               = 0x2F,
  kVK_ANSI_Grave                = 0x32,
  kVK_ANSI_KeypadDecimal        = 0x41,
  kVK_ANSI_KeypadMultiply       = 0x43,
  kVK_ANSI_KeypadPlus           = 0x45,
  kVK_ANSI_KeypadClear          = 0x47,
  kVK_ANSI_KeypadDivide         = 0x4B,
  kVK_ANSI_KeypadEnter          = 0x4C,
  kVK_ANSI_KeypadMinus          = 0x4E,
  kVK_ANSI_KeypadEquals         = 0x51,
  kVK_ANSI_Keypad0              = 0x52,
  kVK_ANSI_Keypad1              = 0x53,
  kVK_ANSI_Keypad2              = 0x54,
  kVK_ANSI_Keypad3              = 0x55,
  kVK_ANSI_Keypad4              = 0x56,
  kVK_ANSI_Keypad5              = 0x57,
  kVK_ANSI_Keypad6              = 0x58,
  kVK_ANSI_Keypad7              = 0x59,
  kVK_ANSI_Keypad8              = 0x5B,
  kVK_ANSI_Keypad9              = 0x5C
};

/* keycodes for keys that are independent of keyboard layout*/
enum {
  kVK_Return                    = 0x24,
  kVK_Tab                       = 0x30,
  kVK_Space                     = 0x31,
  kVK_Delete                    = 0x33,
  kVK_Escape                    = 0x35,
  kVK_Command                   = 0x37,
  kVK_Shift                     = 0x38,
  kVK_CapsLock                  = 0x39,
  kVK_Option                    = 0x3A,
  kVK_Control                   = 0x3B,
  kVK_RightShift                = 0x3C,
  kVK_RightOption               = 0x3D,
  kVK_RightControl              = 0x3E,
  kVK_Function                  = 0x3F,
  kVK_F17                       = 0x40,
  kVK_VolumeUp                  = 0x48,
  kVK_VolumeDown                = 0x49,
  kVK_Mute                      = 0x4A,
  kVK_F18                       = 0x4F,
  kVK_F19                       = 0x50,
  kVK_F20                       = 0x5A,
  kVK_F5                        = 0x60,
  kVK_F6                        = 0x61,
  kVK_F7                        = 0x62,
  kVK_F3                        = 0x63,
  kVK_F8                        = 0x64,
  kVK_F9                        = 0x65,
  kVK_F11                       = 0x67,
  kVK_F13                       = 0x69,
  kVK_F16                       = 0x6A,
  kVK_F14                       = 0x6B,
  kVK_F10                       = 0x6D,
  kVK_F12                       = 0x6F,
  kVK_F15                       = 0x71,
  kVK_Help                      = 0x72,
  kVK_Home                      = 0x73,
  kVK_PageUp                    = 0x74,
  kVK_ForwardDelete             = 0x75,
  kVK_F4                        = 0x76,
  kVK_End                       = 0x77,
  kVK_F2                        = 0x78,
  kVK_PageDown                  = 0x79,
  kVK_F1                        = 0x7A,
  kVK_LeftArrow                 = 0x7B,
  kVK_RightArrow                = 0x7C,
  kVK_DownArrow                 = 0x7D,
  kVK_UpArrow                   = 0x7E
};

Macintosh Toolbox Essentials иллюстрирует физическое расположение этих кодов виртуальных клавиш для Apple Extended Keyboard II в Figure 2-10:

Виртуальные коды клавиш для Apple Extended Keyboard II

Нашел ответ здесь.

Так:

  • Клавиша управления 55
  • Сдвиг 56
  • Caps Lock 57
  • Вариант 58
  • Контроль 59

Я нашел эту замечательную статью во время исследования LibOS.

PS: Коды виртуальных клавиш Mac самые худшие

вот все ключевые коды. Вы можете посмотреть оттуда... или в магазине приложений Mac есть приложение "Key Codes", которое загружает его, и оно может показать вам код клавиши того, что вы нажали клавишу.

В дополнение к кодам клавиш, указанным в других ответах, существуют также "идентификаторы использования", используемые для переназначения ключей в новых API, представленных в macOS Sierra:

Техническое примечание TN2450

Переназначение ключей в macOS 10.12 Sierra

В macOS Sierra 10.12 механизм переназначения ключей был изменен. Это техническое примечание предназначено для разработчиков программного обеспечения для переназначения ключей, чтобы они могли обновить свое программное обеспечение для поддержки macOS Sierra 10.12. В этой технической записке мы представляем 2 решения для реализации функции переназначения клавиш для macOS 10.12.

https://developer.apple.com/library/archive/technotes/tn2450/_index.html

Keyboard a and A - 0x04
Keyboard b and B - 0x05
Keyboard c and C - 0x06
Keyboard d and D - 0x07
Keyboard e and E - 0x08
...

macOS 10.12+

Начиная с macOS Sierra 10.12, keyCodeсоответствует таблицам использования HID универсальной последовательной шины (см. раздел: 10 Страница «Клавиатура/клавиатура», стр. 51).

      Usage           Usage ID (hex)
Keyboard a and A        0x04
Keyboard b and B        0x05
Keyboard c and C        0x06
Keyboard d and D        0x07
Keyboard e and E        0x08
Keyboard f and F        0x09
Keyboard g and G        0x0A
Keyboard h and H        0x0B
Keyboard i and I        0x0C
Keyboard j and J        0x0D
Keyboard k and K        0x0E
Keyboard l and L        0x0F
Keyboard m and M        0x10
Keyboard n and N        0x11
Keyboard o and O        0x12
Keyboard p and P        0x13
Keyboard q and Q        0x14
Keyboard r and R        0x15
Keyboard s and S        0x16
Keyboard t and T        0x17
Keyboard u and U        0x18
Keyboard v and V        0x19
Keyboard w and W        0x1A
Keyboard x and X        0x1B
Keyboard y and Y        0x1C
Keyboard z and Z        0x1D
Keyboard 1 and !        0x1E
Keyboard 2 and @        0x1F
Keyboard 3 and #        0x20
Keyboard 4 and $        0x21
Keyboard 5 and %        0x22
Keyboard 6 and ^        0x23
Keyboard 7 and &        0x24
Keyboard 8 and *        0x25
Keyboard 9 and (        0x26
Keyboard 0 and )        0x27
Keyboard Return (Enter) 0x28
Keyboard Escape         0x29
Keyboard Delete (Backspace)0x2A
Keyboard Tab            0x2B
Keyboard Spacebar       0x2C
Keyboard - and _        0x2D
Keyboard = and +        0x2E
Keyboard [ and {        0x2F
Keyboard ] and }        0x30
Keyboard \ and |        0x31
Keyboard Non-US # and ~ 0x32
Keyboard ; and :        0x33
Keyboard ' and "        0x34
Keyboard Grave Accent and Tilde 0x35
Keyboard , and "<"      0x36
Keyboard . and ">"      0x37
Keyboard / and ?        0x38
Keyboard Caps Lock      0x39
Keyboard F1             0x3A
Keyboard F2             0x3B
Keyboard F3             0x3C
Keyboard F4             0x3D
Keyboard F5             0x3E
Keyboard F6             0x3F
Keyboard F7             0x40
Keyboard F8             0x41
Keyboard F9             0x42
Keyboard F10            0x43
Keyboard F11            0x44
Keyboard F12            0x45
Keyboard Print Screen   0x46
Keyboard Scroll Lock    0x47
Keyboard Pause          0x48
Keyboard Insert         0x49
Keyboard Home           0x4A
Keyboard Page Up        0x4B
Keyboard Delete Forward 0x4C
Keyboard End            0x4D
Keyboard Page Down      0x4E
Keyboard Right Arrow    0x4F
Keyboard Left Arrow     0x50
Keyboard Down Arrow     0x51
Keyboard Up Arrow       0x52
Keypad Num Lock and Clear   0x53
Keypad /                0x54
Keypad *                0x55
Keypad -                0x56
Keypad +                0x57
Keypad Enter            0x58
Keypad 1 and End        0x59
Keypad 2 and Down Arrow 0x5A
Keypad 3 and Page Down  0x5B
Keypad 4 and Left Arrow 0x5C
Keypad 5                0x5D
Keypad 6 and Right Arrow    0x5E
Keypad 7 and Home       0x5F
Keypad 8 and Up Arrow   0x60
Keypad 9 and Page Up    0x61
Keypad 0 and Insert     0x62
Keypad . and Delete     0x63
Keyboard Non-US \ and | 0x64
Keyboard Application    0x65
Keyboard Power          0x66
Keypad =                0x67
Keyboard F13            0x68
Keyboard F14            0x69
Keyboard F15            0x6A
Keyboard F16            0x6B
Keyboard F17            0x6C
Keyboard F18            0x6D
Keyboard F19            0x6E
Keyboard F20            0x6F
Keyboard F21            0x70
Keyboard F22            0x71
Keyboard F23            0x72
Keyboard F24            0x73
Keyboard Left Control   0xE0
Keyboard Left Shift     0xE1
Keyboard Left Alt       0xE2
Keyboard Left GUI       0xE3
Keyboard Right Control  0xE4
Keyboard Right Shift    0xE5
Keyboard Right Alt      0xE6
Keyboard Right GUI      0xE7

Вот несколько готовых словарей Objective-C, если кто-то хочет набирать символы ANSI:

NSDictionary *lowerCaseCodes = @{
                                     @"Q" : [NSNumber numberWithInteger:12],
                                     @"W" : [NSNumber numberWithInteger:    13],
                                     @"E" : [NSNumber numberWithInteger:    14],
                                     @"R" : [NSNumber numberWithInteger:    15],
                                     @"T" : [NSNumber numberWithInteger:    17],
                                     @"Y" : [NSNumber numberWithInteger:    16],
                                     @"U" : [NSNumber numberWithInteger:    32],
                                     @"I" : [NSNumber numberWithInteger:    34],
                                     @"O" : [NSNumber numberWithInteger:    31],
                                     @"P" : [NSNumber numberWithInteger:    35],
                                     @"A" : [NSNumber numberWithInteger:    0],
                                     @"S" : [NSNumber numberWithInteger:    1],
                                     @"D" : [NSNumber numberWithInteger:    2],
                                     @"F" : [NSNumber numberWithInteger:    3],
                                     @"G" : [NSNumber numberWithInteger:    5],
                                     @"H" : [NSNumber numberWithInteger:    4],
                                     @"J" : [NSNumber numberWithInteger:    38],
                                     @"K" : [NSNumber numberWithInteger:    40],
                                     @"L" : [NSNumber numberWithInteger:    37],
                                     @"Z" : [NSNumber numberWithInteger:    6],
                                     @"X" : [NSNumber numberWithInteger:    7],
                                     @"C" : [NSNumber numberWithInteger:    8],
                                     @"V" : [NSNumber numberWithInteger:    9],
                                     @"B" : [NSNumber numberWithInteger:    11],
                                     @"N" : [NSNumber numberWithInteger:    45],
                                     @"M" : [NSNumber numberWithInteger:    46],
                                     @"0" : [NSNumber numberWithInteger:    29],
                                     @"1" : [NSNumber numberWithInteger:    18],
                                     @"2" : [NSNumber numberWithInteger:    19],
                                     @"3" : [NSNumber numberWithInteger:    20],
                                     @"4" : [NSNumber numberWithInteger:    21],
                                     @"5" : [NSNumber numberWithInteger:    23],
                                     @"6" : [NSNumber numberWithInteger:    22],
                                     @"7" : [NSNumber numberWithInteger:    26],
                                     @"8" : [NSNumber numberWithInteger:    28],
                                     @"9" : [NSNumber numberWithInteger:    25],
                                     @" " : [NSNumber numberWithInteger:    49],
                                     @"." : [NSNumber numberWithInteger:    47],
                                     @"," : [NSNumber numberWithInteger:    43],
                                     @"/" : [NSNumber numberWithInteger:    44],
                                     @";" : [NSNumber numberWithInteger:    41],
                                     @"'" : [NSNumber numberWithInteger:    39],
                                     @"[" : [NSNumber numberWithInteger:    33],
                                     @"]" : [NSNumber numberWithInteger:    30],
                                     @"\\" : [NSNumber numberWithInteger:    42],
                                     @"-" : [NSNumber numberWithInteger:    27],
                                     @"=" : [NSNumber numberWithInteger:    24]
                                     };

        NSDictionary *shiftCodes = @{//these keys must be used in conjunction with the shift key
                                     @"<" : [NSNumber numberWithInteger:    43],
                                     @">" : [NSNumber numberWithInteger:    47],
                                     @"?" : [NSNumber numberWithInteger:    44],
                                     @":" : [NSNumber numberWithInteger:    41],
                                     @"\"" : [NSNumber numberWithInteger:   39],
                                     @"{" : [NSNumber numberWithInteger:    33],
                                     @"}" : [NSNumber numberWithInteger:    30],
                                     @"|" : [NSNumber numberWithInteger:    42],
                                     @")" : [NSNumber numberWithInteger:    29],
                                     @"!" : [NSNumber numberWithInteger:    18],
                                     @"@" : [NSNumber numberWithInteger:    19],
                                     @"#" : [NSNumber numberWithInteger:    20],
                                     @"$" : [NSNumber numberWithInteger:    21],
                                     @"%" : [NSNumber numberWithInteger:    23],
                                     @"^" : [NSNumber numberWithInteger:    22],
                                     @"&" : [NSNumber numberWithInteger:    26],
                                     @"*" : [NSNumber numberWithInteger:    28],
                                     @"(" : [NSNumber numberWithInteger:    25],
                                     @"_" : [NSNumber numberWithInteger:    27],
                                     @"+" : [NSNumber numberWithInteger:    24]
                                     };
Другие вопросы по тегам