Path: blob/master/thirdparty/sdl/include/SDL3/SDL_scancode.h
9912 views
/*1Simple DirectMedia Layer2Copyright (C) 1997-2025 Sam Lantinga <[email protected]>34This software is provided 'as-is', without any express or implied5warranty. In no event will the authors be held liable for any damages6arising from the use of this software.78Permission is granted to anyone to use this software for any purpose,9including commercial applications, and to alter it and redistribute it10freely, subject to the following restrictions:11121. The origin of this software must not be misrepresented; you must not13claim that you wrote the original software. If you use this software14in a product, an acknowledgment in the product documentation would be15appreciated but is not required.162. Altered source versions must be plainly marked as such, and must not be17misrepresented as being the original software.183. This notice may not be removed or altered from any source distribution.19*/2021/**22* # CategoryScancode23*24* Defines keyboard scancodes.25*26* Please refer to the Best Keyboard Practices document for details on what27* this information means and how best to use it.28*29* https://wiki.libsdl.org/SDL3/BestKeyboardPractices30*/3132#ifndef SDL_scancode_h_33#define SDL_scancode_h_3435#include <SDL3/SDL_stdinc.h>3637/**38* The SDL keyboard scancode representation.39*40* An SDL scancode is the physical representation of a key on the keyboard,41* independent of language and keyboard mapping.42*43* Values of this type are used to represent keyboard keys, among other places44* in the `scancode` field of the SDL_KeyboardEvent structure.45*46* The values in this enumeration are based on the USB usage page standard:47* https://usb.org/sites/default/files/hut1_5.pdf48*49* \since This enum is available since SDL 3.2.0.50*/51typedef enum SDL_Scancode52{53SDL_SCANCODE_UNKNOWN = 0,5455/**56* \name Usage page 0x0757*58* These values are from usage page 0x07 (USB keyboard page).59*/60/* @{ */6162SDL_SCANCODE_A = 4,63SDL_SCANCODE_B = 5,64SDL_SCANCODE_C = 6,65SDL_SCANCODE_D = 7,66SDL_SCANCODE_E = 8,67SDL_SCANCODE_F = 9,68SDL_SCANCODE_G = 10,69SDL_SCANCODE_H = 11,70SDL_SCANCODE_I = 12,71SDL_SCANCODE_J = 13,72SDL_SCANCODE_K = 14,73SDL_SCANCODE_L = 15,74SDL_SCANCODE_M = 16,75SDL_SCANCODE_N = 17,76SDL_SCANCODE_O = 18,77SDL_SCANCODE_P = 19,78SDL_SCANCODE_Q = 20,79SDL_SCANCODE_R = 21,80SDL_SCANCODE_S = 22,81SDL_SCANCODE_T = 23,82SDL_SCANCODE_U = 24,83SDL_SCANCODE_V = 25,84SDL_SCANCODE_W = 26,85SDL_SCANCODE_X = 27,86SDL_SCANCODE_Y = 28,87SDL_SCANCODE_Z = 29,8889SDL_SCANCODE_1 = 30,90SDL_SCANCODE_2 = 31,91SDL_SCANCODE_3 = 32,92SDL_SCANCODE_4 = 33,93SDL_SCANCODE_5 = 34,94SDL_SCANCODE_6 = 35,95SDL_SCANCODE_7 = 36,96SDL_SCANCODE_8 = 37,97SDL_SCANCODE_9 = 38,98SDL_SCANCODE_0 = 39,99100SDL_SCANCODE_RETURN = 40,101SDL_SCANCODE_ESCAPE = 41,102SDL_SCANCODE_BACKSPACE = 42,103SDL_SCANCODE_TAB = 43,104SDL_SCANCODE_SPACE = 44,105106SDL_SCANCODE_MINUS = 45,107SDL_SCANCODE_EQUALS = 46,108SDL_SCANCODE_LEFTBRACKET = 47,109SDL_SCANCODE_RIGHTBRACKET = 48,110SDL_SCANCODE_BACKSLASH = 49, /**< Located at the lower left of the return111* key on ISO keyboards and at the right end112* of the QWERTY row on ANSI keyboards.113* Produces REVERSE SOLIDUS (backslash) and114* VERTICAL LINE in a US layout, REVERSE115* SOLIDUS and VERTICAL LINE in a UK Mac116* layout, NUMBER SIGN and TILDE in a UK117* Windows layout, DOLLAR SIGN and POUND SIGN118* in a Swiss German layout, NUMBER SIGN and119* APOSTROPHE in a German layout, GRAVE120* ACCENT and POUND SIGN in a French Mac121* layout, and ASTERISK and MICRO SIGN in a122* French Windows layout.123*/124SDL_SCANCODE_NONUSHASH = 50, /**< ISO USB keyboards actually use this code125* instead of 49 for the same key, but all126* OSes I've seen treat the two codes127* identically. So, as an implementor, unless128* your keyboard generates both of those129* codes and your OS treats them differently,130* you should generate SDL_SCANCODE_BACKSLASH131* instead of this code. As a user, you132* should not rely on this code because SDL133* will never generate it with most (all?)134* keyboards.135*/136SDL_SCANCODE_SEMICOLON = 51,137SDL_SCANCODE_APOSTROPHE = 52,138SDL_SCANCODE_GRAVE = 53, /**< Located in the top left corner (on both ANSI139* and ISO keyboards). Produces GRAVE ACCENT and140* TILDE in a US Windows layout and in US and UK141* Mac layouts on ANSI keyboards, GRAVE ACCENT142* and NOT SIGN in a UK Windows layout, SECTION143* SIGN and PLUS-MINUS SIGN in US and UK Mac144* layouts on ISO keyboards, SECTION SIGN and145* DEGREE SIGN in a Swiss German layout (Mac:146* only on ISO keyboards), CIRCUMFLEX ACCENT and147* DEGREE SIGN in a German layout (Mac: only on148* ISO keyboards), SUPERSCRIPT TWO and TILDE in a149* French Windows layout, COMMERCIAL AT and150* NUMBER SIGN in a French Mac layout on ISO151* keyboards, and LESS-THAN SIGN and GREATER-THAN152* SIGN in a Swiss German, German, or French Mac153* layout on ANSI keyboards.154*/155SDL_SCANCODE_COMMA = 54,156SDL_SCANCODE_PERIOD = 55,157SDL_SCANCODE_SLASH = 56,158159SDL_SCANCODE_CAPSLOCK = 57,160161SDL_SCANCODE_F1 = 58,162SDL_SCANCODE_F2 = 59,163SDL_SCANCODE_F3 = 60,164SDL_SCANCODE_F4 = 61,165SDL_SCANCODE_F5 = 62,166SDL_SCANCODE_F6 = 63,167SDL_SCANCODE_F7 = 64,168SDL_SCANCODE_F8 = 65,169SDL_SCANCODE_F9 = 66,170SDL_SCANCODE_F10 = 67,171SDL_SCANCODE_F11 = 68,172SDL_SCANCODE_F12 = 69,173174SDL_SCANCODE_PRINTSCREEN = 70,175SDL_SCANCODE_SCROLLLOCK = 71,176SDL_SCANCODE_PAUSE = 72,177SDL_SCANCODE_INSERT = 73, /**< insert on PC, help on some Mac keyboards (but178does send code 73, not 117) */179SDL_SCANCODE_HOME = 74,180SDL_SCANCODE_PAGEUP = 75,181SDL_SCANCODE_DELETE = 76,182SDL_SCANCODE_END = 77,183SDL_SCANCODE_PAGEDOWN = 78,184SDL_SCANCODE_RIGHT = 79,185SDL_SCANCODE_LEFT = 80,186SDL_SCANCODE_DOWN = 81,187SDL_SCANCODE_UP = 82,188189SDL_SCANCODE_NUMLOCKCLEAR = 83, /**< num lock on PC, clear on Mac keyboards190*/191SDL_SCANCODE_KP_DIVIDE = 84,192SDL_SCANCODE_KP_MULTIPLY = 85,193SDL_SCANCODE_KP_MINUS = 86,194SDL_SCANCODE_KP_PLUS = 87,195SDL_SCANCODE_KP_ENTER = 88,196SDL_SCANCODE_KP_1 = 89,197SDL_SCANCODE_KP_2 = 90,198SDL_SCANCODE_KP_3 = 91,199SDL_SCANCODE_KP_4 = 92,200SDL_SCANCODE_KP_5 = 93,201SDL_SCANCODE_KP_6 = 94,202SDL_SCANCODE_KP_7 = 95,203SDL_SCANCODE_KP_8 = 96,204SDL_SCANCODE_KP_9 = 97,205SDL_SCANCODE_KP_0 = 98,206SDL_SCANCODE_KP_PERIOD = 99,207208SDL_SCANCODE_NONUSBACKSLASH = 100, /**< This is the additional key that ISO209* keyboards have over ANSI ones,210* located between left shift and Y.211* Produces GRAVE ACCENT and TILDE in a212* US or UK Mac layout, REVERSE SOLIDUS213* (backslash) and VERTICAL LINE in a214* US or UK Windows layout, and215* LESS-THAN SIGN and GREATER-THAN SIGN216* in a Swiss German, German, or French217* layout. */218SDL_SCANCODE_APPLICATION = 101, /**< windows contextual menu, compose */219SDL_SCANCODE_POWER = 102, /**< The USB document says this is a status flag,220* not a physical key - but some Mac keyboards221* do have a power key. */222SDL_SCANCODE_KP_EQUALS = 103,223SDL_SCANCODE_F13 = 104,224SDL_SCANCODE_F14 = 105,225SDL_SCANCODE_F15 = 106,226SDL_SCANCODE_F16 = 107,227SDL_SCANCODE_F17 = 108,228SDL_SCANCODE_F18 = 109,229SDL_SCANCODE_F19 = 110,230SDL_SCANCODE_F20 = 111,231SDL_SCANCODE_F21 = 112,232SDL_SCANCODE_F22 = 113,233SDL_SCANCODE_F23 = 114,234SDL_SCANCODE_F24 = 115,235SDL_SCANCODE_EXECUTE = 116,236SDL_SCANCODE_HELP = 117, /**< AL Integrated Help Center */237SDL_SCANCODE_MENU = 118, /**< Menu (show menu) */238SDL_SCANCODE_SELECT = 119,239SDL_SCANCODE_STOP = 120, /**< AC Stop */240SDL_SCANCODE_AGAIN = 121, /**< AC Redo/Repeat */241SDL_SCANCODE_UNDO = 122, /**< AC Undo */242SDL_SCANCODE_CUT = 123, /**< AC Cut */243SDL_SCANCODE_COPY = 124, /**< AC Copy */244SDL_SCANCODE_PASTE = 125, /**< AC Paste */245SDL_SCANCODE_FIND = 126, /**< AC Find */246SDL_SCANCODE_MUTE = 127,247SDL_SCANCODE_VOLUMEUP = 128,248SDL_SCANCODE_VOLUMEDOWN = 129,249/* not sure whether there's a reason to enable these */250/* SDL_SCANCODE_LOCKINGCAPSLOCK = 130, */251/* SDL_SCANCODE_LOCKINGNUMLOCK = 131, */252/* SDL_SCANCODE_LOCKINGSCROLLLOCK = 132, */253SDL_SCANCODE_KP_COMMA = 133,254SDL_SCANCODE_KP_EQUALSAS400 = 134,255256SDL_SCANCODE_INTERNATIONAL1 = 135, /**< used on Asian keyboards, see257footnotes in USB doc */258SDL_SCANCODE_INTERNATIONAL2 = 136,259SDL_SCANCODE_INTERNATIONAL3 = 137, /**< Yen */260SDL_SCANCODE_INTERNATIONAL4 = 138,261SDL_SCANCODE_INTERNATIONAL5 = 139,262SDL_SCANCODE_INTERNATIONAL6 = 140,263SDL_SCANCODE_INTERNATIONAL7 = 141,264SDL_SCANCODE_INTERNATIONAL8 = 142,265SDL_SCANCODE_INTERNATIONAL9 = 143,266SDL_SCANCODE_LANG1 = 144, /**< Hangul/English toggle */267SDL_SCANCODE_LANG2 = 145, /**< Hanja conversion */268SDL_SCANCODE_LANG3 = 146, /**< Katakana */269SDL_SCANCODE_LANG4 = 147, /**< Hiragana */270SDL_SCANCODE_LANG5 = 148, /**< Zenkaku/Hankaku */271SDL_SCANCODE_LANG6 = 149, /**< reserved */272SDL_SCANCODE_LANG7 = 150, /**< reserved */273SDL_SCANCODE_LANG8 = 151, /**< reserved */274SDL_SCANCODE_LANG9 = 152, /**< reserved */275276SDL_SCANCODE_ALTERASE = 153, /**< Erase-Eaze */277SDL_SCANCODE_SYSREQ = 154,278SDL_SCANCODE_CANCEL = 155, /**< AC Cancel */279SDL_SCANCODE_CLEAR = 156,280SDL_SCANCODE_PRIOR = 157,281SDL_SCANCODE_RETURN2 = 158,282SDL_SCANCODE_SEPARATOR = 159,283SDL_SCANCODE_OUT = 160,284SDL_SCANCODE_OPER = 161,285SDL_SCANCODE_CLEARAGAIN = 162,286SDL_SCANCODE_CRSEL = 163,287SDL_SCANCODE_EXSEL = 164,288289SDL_SCANCODE_KP_00 = 176,290SDL_SCANCODE_KP_000 = 177,291SDL_SCANCODE_THOUSANDSSEPARATOR = 178,292SDL_SCANCODE_DECIMALSEPARATOR = 179,293SDL_SCANCODE_CURRENCYUNIT = 180,294SDL_SCANCODE_CURRENCYSUBUNIT = 181,295SDL_SCANCODE_KP_LEFTPAREN = 182,296SDL_SCANCODE_KP_RIGHTPAREN = 183,297SDL_SCANCODE_KP_LEFTBRACE = 184,298SDL_SCANCODE_KP_RIGHTBRACE = 185,299SDL_SCANCODE_KP_TAB = 186,300SDL_SCANCODE_KP_BACKSPACE = 187,301SDL_SCANCODE_KP_A = 188,302SDL_SCANCODE_KP_B = 189,303SDL_SCANCODE_KP_C = 190,304SDL_SCANCODE_KP_D = 191,305SDL_SCANCODE_KP_E = 192,306SDL_SCANCODE_KP_F = 193,307SDL_SCANCODE_KP_XOR = 194,308SDL_SCANCODE_KP_POWER = 195,309SDL_SCANCODE_KP_PERCENT = 196,310SDL_SCANCODE_KP_LESS = 197,311SDL_SCANCODE_KP_GREATER = 198,312SDL_SCANCODE_KP_AMPERSAND = 199,313SDL_SCANCODE_KP_DBLAMPERSAND = 200,314SDL_SCANCODE_KP_VERTICALBAR = 201,315SDL_SCANCODE_KP_DBLVERTICALBAR = 202,316SDL_SCANCODE_KP_COLON = 203,317SDL_SCANCODE_KP_HASH = 204,318SDL_SCANCODE_KP_SPACE = 205,319SDL_SCANCODE_KP_AT = 206,320SDL_SCANCODE_KP_EXCLAM = 207,321SDL_SCANCODE_KP_MEMSTORE = 208,322SDL_SCANCODE_KP_MEMRECALL = 209,323SDL_SCANCODE_KP_MEMCLEAR = 210,324SDL_SCANCODE_KP_MEMADD = 211,325SDL_SCANCODE_KP_MEMSUBTRACT = 212,326SDL_SCANCODE_KP_MEMMULTIPLY = 213,327SDL_SCANCODE_KP_MEMDIVIDE = 214,328SDL_SCANCODE_KP_PLUSMINUS = 215,329SDL_SCANCODE_KP_CLEAR = 216,330SDL_SCANCODE_KP_CLEARENTRY = 217,331SDL_SCANCODE_KP_BINARY = 218,332SDL_SCANCODE_KP_OCTAL = 219,333SDL_SCANCODE_KP_DECIMAL = 220,334SDL_SCANCODE_KP_HEXADECIMAL = 221,335336SDL_SCANCODE_LCTRL = 224,337SDL_SCANCODE_LSHIFT = 225,338SDL_SCANCODE_LALT = 226, /**< alt, option */339SDL_SCANCODE_LGUI = 227, /**< windows, command (apple), meta */340SDL_SCANCODE_RCTRL = 228,341SDL_SCANCODE_RSHIFT = 229,342SDL_SCANCODE_RALT = 230, /**< alt gr, option */343SDL_SCANCODE_RGUI = 231, /**< windows, command (apple), meta */344345SDL_SCANCODE_MODE = 257, /**< I'm not sure if this is really not covered346* by any of the above, but since there's a347* special SDL_KMOD_MODE for it I'm adding it here348*/349350/* @} *//* Usage page 0x07 */351352/**353* \name Usage page 0x0C354*355* These values are mapped from usage page 0x0C (USB consumer page).356*357* There are way more keys in the spec than we can represent in the358* current scancode range, so pick the ones that commonly come up in359* real world usage.360*/361/* @{ */362363SDL_SCANCODE_SLEEP = 258, /**< Sleep */364SDL_SCANCODE_WAKE = 259, /**< Wake */365366SDL_SCANCODE_CHANNEL_INCREMENT = 260, /**< Channel Increment */367SDL_SCANCODE_CHANNEL_DECREMENT = 261, /**< Channel Decrement */368369SDL_SCANCODE_MEDIA_PLAY = 262, /**< Play */370SDL_SCANCODE_MEDIA_PAUSE = 263, /**< Pause */371SDL_SCANCODE_MEDIA_RECORD = 264, /**< Record */372SDL_SCANCODE_MEDIA_FAST_FORWARD = 265, /**< Fast Forward */373SDL_SCANCODE_MEDIA_REWIND = 266, /**< Rewind */374SDL_SCANCODE_MEDIA_NEXT_TRACK = 267, /**< Next Track */375SDL_SCANCODE_MEDIA_PREVIOUS_TRACK = 268, /**< Previous Track */376SDL_SCANCODE_MEDIA_STOP = 269, /**< Stop */377SDL_SCANCODE_MEDIA_EJECT = 270, /**< Eject */378SDL_SCANCODE_MEDIA_PLAY_PAUSE = 271, /**< Play / Pause */379SDL_SCANCODE_MEDIA_SELECT = 272, /* Media Select */380381SDL_SCANCODE_AC_NEW = 273, /**< AC New */382SDL_SCANCODE_AC_OPEN = 274, /**< AC Open */383SDL_SCANCODE_AC_CLOSE = 275, /**< AC Close */384SDL_SCANCODE_AC_EXIT = 276, /**< AC Exit */385SDL_SCANCODE_AC_SAVE = 277, /**< AC Save */386SDL_SCANCODE_AC_PRINT = 278, /**< AC Print */387SDL_SCANCODE_AC_PROPERTIES = 279, /**< AC Properties */388389SDL_SCANCODE_AC_SEARCH = 280, /**< AC Search */390SDL_SCANCODE_AC_HOME = 281, /**< AC Home */391SDL_SCANCODE_AC_BACK = 282, /**< AC Back */392SDL_SCANCODE_AC_FORWARD = 283, /**< AC Forward */393SDL_SCANCODE_AC_STOP = 284, /**< AC Stop */394SDL_SCANCODE_AC_REFRESH = 285, /**< AC Refresh */395SDL_SCANCODE_AC_BOOKMARKS = 286, /**< AC Bookmarks */396397/* @} *//* Usage page 0x0C */398399400/**401* \name Mobile keys402*403* These are values that are often used on mobile phones.404*/405/* @{ */406407SDL_SCANCODE_SOFTLEFT = 287, /**< Usually situated below the display on phones and408used as a multi-function feature key for selecting409a software defined function shown on the bottom left410of the display. */411SDL_SCANCODE_SOFTRIGHT = 288, /**< Usually situated below the display on phones and412used as a multi-function feature key for selecting413a software defined function shown on the bottom right414of the display. */415SDL_SCANCODE_CALL = 289, /**< Used for accepting phone calls. */416SDL_SCANCODE_ENDCALL = 290, /**< Used for rejecting phone calls. */417418/* @} *//* Mobile keys */419420/* Add any other keys here. */421422SDL_SCANCODE_RESERVED = 400, /**< 400-500 reserved for dynamic keycodes */423424SDL_SCANCODE_COUNT = 512 /**< not a key, just marks the number of scancodes for array bounds */425426} SDL_Scancode;427428#endif /* SDL_scancode_h_ */429430431