You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

551 lines
43 KiB

  1. # Keycodes Overview
  2. When defining a [keymap](keymap.md) each key needs a valid key definition. This page documents the symbols that correspond to keycodes that are available to you in QMK.
  3. This is a reference only. Each group of keys links to the page documenting their functionality in more detail.
  4. ## Basic Keycodes :id=basic-keycodes
  5. See also: [Basic Keycodes](keycodes_basic.md)
  6. |Key |Aliases |Description |
  7. |-----------------------|------------------------------|-----------------------------------------------|
  8. |`KC_NO` |`XXXXXXX` |Ignore this key (NOOP) |
  9. |`KC_TRANSPARENT` |`KC_TRNS`, `_______` |Use the next lowest non-transparent key |
  10. |`KC_A` | |`a` and `A` |
  11. |`KC_B` | |`b` and `B` |
  12. |`KC_C` | |`c` and `C` |
  13. |`KC_D` | |`d` and `D` |
  14. |`KC_E` | |`e` and `E` |
  15. |`KC_F` | |`f` and `F` |
  16. |`KC_G` | |`g` and `G` |
  17. |`KC_H` | |`h` and `H` |
  18. |`KC_I` | |`i` and `I` |
  19. |`KC_J` | |`j` and `J` |
  20. |`KC_K` | |`k` and `K` |
  21. |`KC_L` | |`l` and `L` |
  22. |`KC_M` | |`m` and `M` |
  23. |`KC_N` | |`n` and `N` |
  24. |`KC_O` | |`o` and `O` |
  25. |`KC_P` | |`p` and `P` |
  26. |`KC_Q` | |`q` and `Q` |
  27. |`KC_R` | |`r` and `R` |
  28. |`KC_S` | |`s` and `S` |
  29. |`KC_T` | |`t` and `T` |
  30. |`KC_U` | |`u` and `U` |
  31. |`KC_V` | |`v` and `V` |
  32. |`KC_W` | |`w` and `W` |
  33. |`KC_X` | |`x` and `X` |
  34. |`KC_Y` | |`y` and `Y` |
  35. |`KC_Z` | |`z` and `Z` |
  36. |`KC_1` | |`1` and `!` |
  37. |`KC_2` | |`2` and `@` |
  38. |`KC_3` | |`3` and `#` |
  39. |`KC_4` | |`4` and `$` |
  40. |`KC_5` | |`5` and `%` |
  41. |`KC_6` | |`6` and `^` |
  42. |`KC_7` | |`7` and `&` |
  43. |`KC_8` | |`8` and `*` |
  44. |`KC_9` | |`9` and `(` |
  45. |`KC_0` | |`0` and `)` |
  46. |`KC_ENTER` |`KC_ENT` |Return (Enter) |
  47. |`KC_ESCAPE` |`KC_ESC` |Escape |
  48. |`KC_BSPACE` |`KC_BSPC` |Delete (Backspace) |
  49. |`KC_TAB` | |Tab |
  50. |`KC_SPACE` |`KC_SPC` |Spacebar |
  51. |`KC_MINUS` |`KC_MINS` |`-` and `_` |
  52. |`KC_EQUAL` |`KC_EQL` |`=` and `+` |
  53. |`KC_LBRACKET` |`KC_LBRC` |`[` and `{` |
  54. |`KC_RBRACKET` |`KC_RBRC` |`]` and `}` |
  55. |`KC_BSLASH` |`KC_BSLS` |`\` and `\|` |
  56. |`KC_NONUS_HASH` |`KC_NUHS` |Non-US `#` and `~` |
  57. |`KC_SCOLON` |`KC_SCLN` |`;` and `:` |
  58. |`KC_QUOTE` |`KC_QUOT` |`'` and `"` |
  59. |`KC_GRAVE` |`KC_GRV`, `KC_ZKHK` |<code>&#96;</code> and `~`, JIS Zenkaku/Hankaku|
  60. |`KC_COMMA` |`KC_COMM` |`,` and `<` |
  61. |`KC_DOT` | |`.` and `>` |
  62. |`KC_SLASH` |`KC_SLSH` |`/` and `?` |
  63. |`KC_CAPSLOCK` |`KC_CLCK`, `KC_CAPS` |Caps Lock |
  64. |`KC_F1` | |F1 |
  65. |`KC_F2` | |F2 |
  66. |`KC_F3` | |F3 |
  67. |`KC_F4` | |F4 |
  68. |`KC_F5` | |F5 |
  69. |`KC_F6` | |F6 |
  70. |`KC_F7` | |F7 |
  71. |`KC_F8` | |F8 |
  72. |`KC_F9` | |F9 |
  73. |`KC_F10` | |F10 |
  74. |`KC_F11` | |F11 |
  75. |`KC_F12` | |F12 |
  76. |`KC_PSCREEN` |`KC_PSCR` |Print Screen |
  77. |`KC_SCROLLLOCK` |`KC_SLCK`, `KC_BRMD` |Scroll Lock, Brightness Down (macOS) |
  78. |`KC_PAUSE` |`KC_PAUS`, `KC_BRK`, `KC_BRMU`|Pause, Brightness Up (macOS) |
  79. |`KC_INSERT` |`KC_INS` |Insert |
  80. |`KC_HOME` | |Home |
  81. |`KC_PGUP` | |Page Up |
  82. |`KC_DELETE` |`KC_DEL` |Forward Delete |
  83. |`KC_END` | |End |
  84. |`KC_PGDOWN` |`KC_PGDN` |Page Down |
  85. |`KC_RIGHT` |`KC_RGHT` |Right Arrow |
  86. |`KC_LEFT` | |Left Arrow |
  87. |`KC_DOWN` | |Down Arrow |
  88. |`KC_UP` | |Up Arrow |
  89. |`KC_NUMLOCK` |`KC_NLCK` |Keypad Num Lock and Clear |
  90. |`KC_KP_SLASH` |`KC_PSLS` |Keypad `/` |
  91. |`KC_KP_ASTERISK` |`KC_PAST` |Keypad `*` |
  92. |`KC_KP_MINUS` |`KC_PMNS` |Keypad `-` |
  93. |`KC_KP_PLUS` |`KC_PPLS` |Keypad `+` |
  94. |`KC_KP_ENTER` |`KC_PENT` |Keypad Enter |
  95. |`KC_KP_1` |`KC_P1` |Keypad `1` and End |
  96. |`KC_KP_2` |`KC_P2` |Keypad `2` and Down Arrow |
  97. |`KC_KP_3` |`KC_P3` |Keypad `3` and Page Down |
  98. |`KC_KP_4` |`KC_P4` |Keypad `4` and Left Arrow |
  99. |`KC_KP_5` |`KC_P5` |Keypad `5` |
  100. |`KC_KP_6` |`KC_P6` |Keypad `6` and Right Arrow |
  101. |`KC_KP_7` |`KC_P7` |Keypad `7` and Home |
  102. |`KC_KP_8` |`KC_P8` |Keypad `8` and Up Arrow |
  103. |`KC_KP_9` |`KC_P9` |Keypad `9` and Page Up |
  104. |`KC_KP_0` |`KC_P0` |Keypad `0` and Insert |
  105. |`KC_KP_DOT` |`KC_PDOT` |Keypad `.` and Delete |
  106. |`KC_NONUS_BSLASH` |`KC_NUBS` |Non-US `\` and `\|` |
  107. |`KC_APPLICATION` |`KC_APP` |Application (Windows Menu Key) |
  108. |`KC_POWER` | |System Power (macOS) |
  109. |`KC_KP_EQUAL` |`KC_PEQL` |Keypad `=` |
  110. |`KC_F13` | |F13 |
  111. |`KC_F14` | |F14 |
  112. |`KC_F15` | |F15 |
  113. |`KC_F16` | |F16 |
  114. |`KC_F17` | |F17 |
  115. |`KC_F18` | |F18 |
  116. |`KC_F19` | |F19 |
  117. |`KC_F20` | |F20 |
  118. |`KC_F21` | |F21 |
  119. |`KC_F22` | |F22 |
  120. |`KC_F23` | |F23 |
  121. |`KC_F24` | |F24 |
  122. |`KC_EXECUTE` |`KC_EXEC` |Execute |
  123. |`KC_HELP` | |Help |
  124. |`KC_MENU` | |Menu |
  125. |`KC_SELECT` |`KC_SLCT` |Select |
  126. |`KC_STOP` | |Stop |
  127. |`KC_AGAIN` |`KC_AGIN` |Again |
  128. |`KC_UNDO` | |Undo |
  129. |`KC_CUT` | |Cut |
  130. |`KC_COPY` | |Copy |
  131. |`KC_PASTE` |`KC_PSTE` |Paste |
  132. |`KC_FIND` | |Find |
  133. |`KC__MUTE` | |Mute (macOS) |
  134. |`KC__VOLUP` | |Volume Up (macOS) |
  135. |`KC__VOLDOWN` | |Volume Down (macOS) |
  136. |`KC_LOCKING_CAPS` |`KC_LCAP` |Locking Caps Lock |
  137. |`KC_LOCKING_NUM` |`KC_LNUM` |Locking Num Lock |
  138. |`KC_LOCKING_SCROLL` |`KC_LSCR` |Locking Scroll Lock |
  139. |`KC_KP_COMMA` |`KC_PCMM` |Keypad `,` |
  140. |`KC_KP_EQUAL_AS400` | |Keypad `=` on AS/400 keyboards |
  141. |`KC_INT1` |`KC_RO` |JIS `\` and `_` |
  142. |`KC_INT2` |`KC_KANA` |JIS Katakana/Hiragana |
  143. |`KC_INT3` |`KC_JYEN` |JIS `¥` and `\|` |
  144. |`KC_INT4` |`KC_HENK` |JIS Henkan |
  145. |`KC_INT5` |`KC_MHEN` |JIS Muhenkan |
  146. |`KC_INT6` | |JIS Numpad `,` |
  147. |`KC_INT7` | |International 7 |
  148. |`KC_INT8` | |International 8 |
  149. |`KC_INT9` | |International 9 |
  150. |`KC_LANG1` |`KC_HAEN` |Hangul/English |
  151. |`KC_LANG2` |`KC_HANJ` |Hanja |
  152. |`KC_LANG3` | |JIS Katakana |
  153. |`KC_LANG4` | |JIS Hiragana |
  154. |`KC_LANG5` | |JIS Zenkaku/Hankaku |
  155. |`KC_LANG6` | |Language 6 |
  156. |`KC_LANG7` | |Language 7 |
  157. |`KC_LANG8` | |Language 8 |
  158. |`KC_LANG9` | |Language 9 |
  159. |`KC_ALT_ERASE` |`KC_ERAS` |Alternate Erase |
  160. |`KC_SYSREQ` | |SysReq/Attention |
  161. |`KC_CANCEL` | |Cancel |
  162. |`KC_CLEAR` |`KC_CLR` |Clear |
  163. |`KC_PRIOR` | |Prior |
  164. |`KC_RETURN` | |Return |
  165. |`KC_SEPARATOR` | |Separator |
  166. |`KC_OUT` | |Out |
  167. |`KC_OPER` | |Oper |
  168. |`KC_CLEAR_AGAIN` | |Clear/Again |
  169. |`KC_CRSEL` | |CrSel/Props |
  170. |`KC_EXSEL` | |ExSel |
  171. |`KC_LCTRL` |`KC_LCTL` |Left Control |
  172. |`KC_LSHIFT` |`KC_LSFT` |Left Shift |
  173. |`KC_LALT` |`KC_LOPT` |Left Alt (Option) |
  174. |`KC_LGUI` |`KC_LCMD`, `KC_LWIN` |Left GUI (Windows/Command/Meta key) |
  175. |`KC_RCTRL` |`KC_RCTL` |Right Control |
  176. |`KC_RSHIFT` |`KC_RSFT` |Right Shift |
  177. |`KC_RALT` |`KC_ROPT`, `KC_ALGR` |Right Alt (Option/AltGr) |
  178. |`KC_RGUI` |`KC_RCMD`, `KC_RWIN` |Right GUI (Windows/Command/Meta key) |
  179. |`KC_SYSTEM_POWER` |`KC_PWR` |System Power Down |
  180. |`KC_SYSTEM_SLEEP` |`KC_SLEP` |System Sleep |
  181. |`KC_SYSTEM_WAKE` |`KC_WAKE` |System Wake |
  182. |`KC_AUDIO_MUTE` |`KC_MUTE` |Mute |
  183. |`KC_AUDIO_VOL_UP` |`KC_VOLU` |Volume Up |
  184. |`KC_AUDIO_VOL_DOWN` |`KC_VOLD` |Volume Down |
  185. |`KC_MEDIA_NEXT_TRACK` |`KC_MNXT` |Next Track |
  186. |`KC_MEDIA_PREV_TRACK` |`KC_MPRV` |Previous Track |
  187. |`KC_MEDIA_STOP` |`KC_MSTP` |Stop Track (Windows) |
  188. |`KC_MEDIA_PLAY_PAUSE` |`KC_MPLY` |Play/Pause Track |
  189. |`KC_MEDIA_SELECT` |`KC_MSEL` |Launch Media Player (Windows) |
  190. |`KC_MEDIA_EJECT` |`KC_EJCT` |Eject (macOS) |
  191. |`KC_MAIL` | |Launch Mail (Windows) |
  192. |`KC_CALCULATOR` |`KC_CALC` |Launch Calculator (Windows) |
  193. |`KC_MY_COMPUTER` |`KC_MYCM` |Launch My Computer (Windows) |
  194. |`KC_WWW_SEARCH` |`KC_WSCH` |Browser Search (Windows) |
  195. |`KC_WWW_HOME` |`KC_WHOM` |Browser Home (Windows) |
  196. |`KC_WWW_BACK` |`KC_WBAK` |Browser Back (Windows) |
  197. |`KC_WWW_FORWARD` |`KC_WFWD` |Browser Forward (Windows) |
  198. |`KC_WWW_STOP` |`KC_WSTP` |Browser Stop (Windows) |
  199. |`KC_WWW_REFRESH` |`KC_WREF` |Browser Refresh (Windows) |
  200. |`KC_WWW_FAVORITES` |`KC_WFAV` |Browser Favorites (Windows) |
  201. |`KC_MEDIA_FAST_FORWARD`|`KC_MFFD` |Next Track (macOS) |
  202. |`KC_MEDIA_REWIND` |`KC_MRWD` |Previous Track (macOS) |
  203. |`KC_BRIGHTNESS_UP` |`KC_BRIU` |Brightness Up |
  204. |`KC_BRIGHTNESS_DOWN` |`KC_BRID` |Brightness Down |
  205. ## Quantum Keycodes :id=quantum-keycodes
  206. See also: [Quantum Keycodes](quantum_keycodes.md#qmk-keycodes)
  207. |Key |Aliases |Description |
  208. |--------------|---------|-------------------------------------------------------|
  209. |`RESET` | |Put the keyboard into bootloader mode for flashing |
  210. |`DEBUG` | |Toggle debug mode |
  211. |`EEPROM_RESET`|`EEP_RST`|Reinitializes the keyboard's EEPROM (persistent memory)|
  212. ## Audio Keys :id=audio-keys
  213. See also: [Audio](feature_audio.md)
  214. |Key |Aliases |Description |
  215. |----------------|---------|----------------------------------|
  216. |`AU_ON` | |Turns on Audio Feature |
  217. |`AU_OFF` | |Turns off Audio Feature |
  218. |`AU_TOG` | |Toggles Audio state |
  219. |`CLICKY_TOGGLE` |`CK_TOGG`|Toggles Audio clicky mode |
  220. |`CLICKY_UP` |`CK_UP` |Increases frequency of the clicks |
  221. |`CLICKY_DOWN` |`CK_DOWN`|Decreases frequency of the clicks |
  222. |`CLICKY_RESET` |`CK_RST` |Resets frequency to default |
  223. |`MU_ON` | |Turns on Music Mode |
  224. |`MU_OFF` | |Turns off Music Mode |
  225. |`MU_TOG` | |Toggles Music Mode |
  226. |`MU_MOD` | |Cycles through the music modes |
  227. ## Backlighting :id=backlighting
  228. See also: [Backlighting](feature_backlight.md)
  229. |Key |Description |
  230. |---------|------------------------------------------|
  231. |`BL_TOGG`|Turn the backlight on or off |
  232. |`BL_STEP`|Cycle through backlight levels |
  233. |`BL_ON` |Set the backlight to max brightness |
  234. |`BL_OFF` |Turn the backlight off |
  235. |`BL_INC` |Increase the backlight level |
  236. |`BL_DEC` |Decrease the backlight level |
  237. |`BL_BRTG`|Toggle backlight breathing |
  238. ## Bootmagic :id=bootmagic
  239. See also: [Bootmagic](feature_bootmagic.md)
  240. |Key |Aliases |Description |
  241. |----------------------------------|---------|--------------------------------------------------------------------------|
  242. |`MAGIC_SWAP_CONTROL_CAPSLOCK` |`CL_SWAP`|Swap Caps Lock and Left Control |
  243. |`MAGIC_UNSWAP_CONTROL_CAPSLOCK` |`CL_NORM`|Unswap Caps Lock and Left Control |
  244. |`MAGIC_CAPSLOCK_TO_CONTROL` |`CL_CTRL`|Treat Caps Lock as Control |
  245. |`MAGIC_UNCAPSLOCK_TO_CONTROL` |`CL_CAPS`|Stop treating Caps Lock as Control |
  246. |`MAGIC_SWAP_LCTL_LGUI` |`LCG_SWP`|Swap Left Control and GUI |
  247. |`MAGIC_UNSWAP_LCTL_LGUI` |`LCG_NRM`|Unswap Left Control and GUI |
  248. |`MAGIC_SWAP_RCTL_RGUI` |`RCG_SWP`|Swap Right Control and GUI |
  249. |`MAGIC_UNSWAP_RCTL_RGUI` |`RCG_NRM`|Unswap Right Control and GUI |
  250. |`MAGIC_SWAP_CTL_GUI` |`CG_SWAP`|Swap Control and GUI on both sides |
  251. |`MAGIC_UNSWAP_CTL_GUI` |`CG_NORM`|Unswap Control and GUI on both sides |
  252. |`MAGIC_TOGGLE_CTL_GUI` |`CG_TOGG`|Toggle Control and GUI swap on both sides |
  253. |`MAGIC_SWAP_LALT_LGUI` |`LAG_SWP`|Swap Left Alt and GUI |
  254. |`MAGIC_UNSWAP_LALT_LGUI` |`LAG_NRM`|Unswap Left Alt and GUI |
  255. |`MAGIC_SWAP_RALT_RGUI` |`RAG_SWP`|Swap Right Alt and GUI |
  256. |`MAGIC_UNSWAP_RALT_RGUI` |`RAG_NRM`|Unswap Right Alt and GUI |
  257. |`MAGIC_SWAP_ALT_GUI` |`AG_SWAP`|Swap Alt and GUI on both sides |
  258. |`MAGIC_UNSWAP_ALT_GUI` |`AG_NORM`|Unswap Alt and GUI on both sides |
  259. |`MAGIC_TOGGLE_ALT_GUI` |`AG_TOGG`|Toggle Alt and GUI swap on both sides |
  260. |`MAGIC_NO_GUI` |`GUI_OFF`|Disable the GUI keys |
  261. |`MAGIC_UNNO_GUI` |`GUI_ON` |Enable the GUI keys |
  262. |`MAGIC_SWAP_GRAVE_ESC` |`GE_SWAP`|Swap <code>&#96;</code> and Escape |
  263. |`MAGIC_UNSWAP_GRAVE_ESC` |`GE_NORM`|Unswap <code>&#96;</code> and Escape |
  264. |`MAGIC_SWAP_BACKSLASH_BACKSPACE` |`BS_SWAP`|Swap `\` and Backspace |
  265. |`MAGIC_UNSWAP_BACKSLASH_BACKSPACE`|`BS_NORM`|Unswap `\` and Backspace |
  266. |`MAGIC_HOST_NKRO` |`NK_ON` |Enable N-key rollover |
  267. |`MAGIC_UNHOST_NKRO` |`NK_OFF` |Disable N-key rollover |
  268. |`MAGIC_TOGGLE_NKRO` |`NK_TOGG`|Toggle N-key rollover |
  269. |`MAGIC_EE_HANDS_LEFT` |`EH_LEFT`|Set the master half of a split keyboard as the left hand (for `EE_HANDS`) |
  270. |`MAGIC_EE_HANDS_RIGHT` |`EH_RGHT`|Set the master half of a split keyboard as the right hand (for `EE_HANDS`)|
  271. ## Bluetooth :id=bluetooth
  272. See also: [Bluetooth](feature_bluetooth.md)
  273. |Key |Description |
  274. |----------|----------------------------------------------|
  275. |`OUT_AUTO`|Automatically switch between USB and Bluetooth|
  276. |`OUT_USB` |USB only |
  277. |`OUT_BT` |Bluetooth only |
  278. ## Dynamic Macros :id=dynamic-macros
  279. See also: [Dynamic Macros](feature_dynamic_macros.md)
  280. |Key |Aliases |Description |
  281. |-----------------|---------|--------------------------------------------------|
  282. |`DYN_REC_START1` |`DM_REC1`|Start recording Macro 1 |
  283. |`DYN_REC_START2` |`DM_REC2`|Start recording Macro 2 |
  284. |`DYN_MACRO_PLAY1`|`DM_PLY1`|Replay Macro 1 |
  285. |`DYN_MACRO_PLAY2`|`DM_PLY2`|Replay Macro 2 |
  286. |`DYN_REC_STOP` |`DM_RSTP`|Finish the macro that is currently being recorded.|
  287. ## Grave Escape :id=grave-escape
  288. See also: [Grave Escape](feature_grave_esc.md)
  289. |Key |Aliases |Description |
  290. |-----------|---------|------------------------------------------------------------------|
  291. |`GRAVE_ESC`|`KC_GESC`|Escape when pressed, <code>&#96;</code> when Shift or GUI are held|
  292. ## Key Lock :id=key-lock
  293. See also: [Key Lock](feature_key_lock.md)
  294. |Key |Description |
  295. |---------|--------------------------------------------------------------|
  296. |`KC_LOCK`|Hold down the next key pressed, until the key is pressed again|
  297. ## Layer Switching :id=layer-switching
  298. See also: [Layer Switching](feature_layers.md#switching-and-toggling-layers)
  299. |Key |Description |
  300. |----------------|----------------------------------------------------------------------------------|
  301. |`DF(layer)` |Set the base (default) layer |
  302. |`MO(layer)` |Momentarily turn on `layer` when pressed (requires `KC_TRNS` on destination layer)|
  303. |`OSL(layer)` |Momentarily activates `layer` until a key is pressed. See [One Shot Keys](one_shot_keys.md) for details. |
  304. |`LM(layer, mod)`|Momentarily turn on `layer` (like MO) with `mod` active as well. Where `mod` is a mods_bit. Mods can be viewed [here](mod_tap.md). Example Implementation: `LM(LAYER_1, MOD_LALT)`|
  305. |`LT(layer, kc)` |Turn on `layer` when held, `kc` when tapped |
  306. |`TG(layer)` |Toggle `layer` on or off |
  307. |`TO(layer)` |Turns on `layer` and turns off all other layers, except the default layer |
  308. |`TT(layer)` |Normally acts like MO unless it's tapped multiple times, which toggles `layer` on |
  309. ## Leader Key :id=leader-key
  310. See also: [Leader Key](feature_leader_key.md)
  311. |Key |Description |
  312. |---------|------------------------|
  313. |`KC_LEAD`|Begins a leader sequence|
  314. ## Mouse Keys :id=mouse-keys
  315. See also: [Mouse Keys](feature_mouse_keys.md)
  316. |Key |Aliases |Description |
  317. |----------------|---------|---------------------------|
  318. |`KC_MS_UP` |`KC_MS_U`|Mouse Cursor Up |
  319. |`KC_MS_DOWN` |`KC_MS_D`|Mouse Cursor Down |
  320. |`KC_MS_LEFT` |`KC_MS_L`|Mouse Cursor Left |
  321. |`KC_MS_RIGHT` |`KC_MS_R`|Mouse Cursor Right |
  322. |`KC_MS_BTN1` |`KC_BTN1`|Mouse Button 1 |
  323. |`KC_MS_BTN2` |`KC_BTN2`|Mouse Button 2 |
  324. |`KC_MS_BTN3` |`KC_BTN3`|Mouse Button 3 |
  325. |`KC_MS_BTN4` |`KC_BTN4`|Mouse Button 4 |
  326. |`KC_MS_BTN5` |`KC_BTN5`|Mouse Button 5 |
  327. |`KC_MS_WH_UP` |`KC_WH_U`|Mouse Wheel Up |
  328. |`KC_MS_WH_DOWN` |`KC_WH_D`|Mouse Wheel Down |
  329. |`KC_MS_WH_LEFT` |`KC_WH_L`|Mouse Wheel Left |
  330. |`KC_MS_WH_RIGHT`|`KC_WH_R`|Mouse Wheel Right |
  331. |`KC_MS_ACCEL0` |`KC_ACL0`|Set mouse acceleration to 0|
  332. |`KC_MS_ACCEL1` |`KC_ACL1`|Set mouse acceleration to 1|
  333. |`KC_MS_ACCEL2` |`KC_ACL2`|Set mouse acceleration to 2|
  334. ## Modifiers :id=modifiers
  335. See also: [Modifier Keys](feature_advanced_keycodes.md#modifier-keys)
  336. |Key |Aliases |Description |
  337. |----------|-------------------------------|----------------------------------------------------|
  338. |`LCTL(kc)`|`C(kc)` |Hold Left Control and press `kc` |
  339. |`LSFT(kc)`|`S(kc)` |Hold Left Shift and press `kc` |
  340. |`LALT(kc)`|`A(kc)`, `LOPT(kc)` |Hold Left Alt and press `kc` |
  341. |`LGUI(kc)`|`G(kc)`, `LCMD(kc)`, `LWIN(kc)`|Hold Left GUI and press `kc` |
  342. |`RCTL(kc)`| |Hold Right Control and press `kc` |
  343. |`RSFT(kc)`| |Hold Right Shift and press `kc` |
  344. |`RALT(kc)`|`ROPT(kc)`, `ALGR(kc)` |Hold Right Alt and press `kc` |
  345. |`RGUI(kc)`|`RCMD(kc)`, `LWIN(kc)` |Hold Right GUI and press `kc` |
  346. |`SGUI(kc)`|`SCMD(kc)`, `SWIN(kc)` |Hold Left Shift and GUI and press `kc` |
  347. |`LCA(kc)` | |Hold Left Control and Alt and press `kc` |
  348. |`LCAG(kc)`| |Hold Left Control, Alt and GUI and press `kc` |
  349. |`MEH(kc)` | |Hold Left Control, Shift and Alt and press `kc` |
  350. |`HYPR(kc)`| |Hold Left Control, Shift, Alt and GUI and press `kc`|
  351. |`KC_MEH` | |Left Control, Shift and Alt |
  352. |`KC_HYPR` | |Left Control, Shift, Alt and GUI |
  353. ## Mod-Tap Keys :id=mod-tap-keys
  354. See also: [Mod-Tap](mod_tap.md)
  355. |Key |Aliases |Description |
  356. |-------------|-----------------------------------------------------------------|-------------------------------------------------------|
  357. |`MT(mod, kc)`| |`mod` when held, `kc` when tapped |
  358. |`LCTL_T(kc)` |`CTL_T(kc)` |Left Control when held, `kc` when tapped |
  359. |`LSFT_T(kc)` |`SFT_T(kc)` |Left Shift when held, `kc` when tapped |
  360. |`LALT_T(kc)` |`LOPT_T(kc)`, `ALT_T(kc)`, `OPT_T(kc)` |Left Alt when held, `kc` when tapped |
  361. |`LGUI_T(kc)` |`LCMD_T(kc)`, `LWIN_T(kc)`, `GUI_T(kc)`, `CMD_T(kc)`, `WIN_T(kc)`|Left GUI when held, `kc` when tapped |
  362. |`RCTL_T(kc)` | |Right Control when held, `kc` when tapped |
  363. |`RSFT_T(kc)` | |Right Shift when held, `kc` when tapped |
  364. |`RALT_T(kc)` |`ROPT_T(kc)`, `ALGR_T(kc)` |Right Alt when held, `kc` when tapped |
  365. |`RGUI_T(kc)` |`RCMD_T(kc)`, `RWIN_T(kc)` |Right GUI when held, `kc` when tapped |
  366. |`SGUI_T(kc)` |`SCMD_T(kc)`, `SWIN_T(kc)` |Left Shift and GUI when held, `kc` when tapped |
  367. |`LCA_T(kc)` | |Left Control and Alt when held, `kc` when tapped |
  368. |`LCAG_T(kc)` | |Left Control, Alt and GUI when held, `kc` when tapped |
  369. |`RCAG_T(kc)` | |Right Control, Alt and GUI when held, `kc` when tapped |
  370. |`C_S_T(kc)` | |Left Control and Shift when held, `kc` when tapped |
  371. |`MEH_T(kc)` | |Left Control, Shift and Alt when held, `kc` when tapped|
  372. |`HYPR_T(kc)` |`ALL_T(kc)` |Left Control, Shift, Alt and GUI when held, `kc` when tapped - more info [here](http://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/)|
  373. ## RGB Lighting :id=rgb-lighting
  374. See also: [RGB Lighting](feature_rgblight.md)
  375. |Key |Aliases |Description |
  376. |-------------------|----------|--------------------------------------------------------------------|
  377. |`RGB_TOG` | |Toggle RGB lighting on or off |
  378. |`RGB_MODE_FORWARD` |`RGB_MOD` |Cycle through modes, reverse direction when Shift is held |
  379. |`RGB_MODE_REVERSE` |`RGB_RMOD`|Cycle through modes in reverse, forward direction when Shift is held|
  380. |`RGB_HUI` | |Increase hue, decrease hue when Shift is held |
  381. |`RGB_HUD` | |Decrease hue, increase hue when Shift is held |
  382. |`RGB_SAI` | |Increase saturation, decrease saturation when Shift is held |
  383. |`RGB_SAD` | |Decrease saturation, increase saturation when Shift is held |
  384. |`RGB_VAI` | |Increase value (brightness), decrease value when Shift is held |
  385. |`RGB_VAD` | |Decrease value (brightness), increase value when Shift is held |
  386. |`RGB_MODE_PLAIN` |`RGB_M_P `|Static (no animation) mode |
  387. |`RGB_MODE_BREATHE` |`RGB_M_B` |Breathing animation mode |
  388. |`RGB_MODE_RAINBOW` |`RGB_M_R` |Rainbow animation mode |
  389. |`RGB_MODE_SWIRL` |`RGB_M_SW`|Swirl animation mode |
  390. |`RGB_MODE_SNAKE` |`RGB_M_SN`|Snake animation mode |
  391. |`RGB_MODE_KNIGHT` |`RGB_M_K` |"Knight Rider" animation mode |
  392. |`RGB_MODE_XMAS` |`RGB_M_X` |Christmas animation mode |
  393. |`RGB_MODE_GRADIENT`|`RGB_M_G` |Static gradient animation mode |
  394. |`RGB_MODE_RGBTEST` |`RGB_M_T` |Red,Green,Blue test animation mode |
  395. ## RGB Matrix Lighting :id=rgb-matrix-lighting
  396. See also: [RGB Matrix Lighting](feature_rgb_matrix.md)
  397. |Key |Aliases |Description |
  398. |-------------------|----------|--------------------------------------------------------------------------------------|
  399. |`RGB_TOG` | |Toggle RGB lighting on or off |
  400. |`RGB_MODE_FORWARD` |`RGB_MOD` |Cycle through modes, reverse direction when Shift is held |
  401. |`RGB_MODE_REVERSE` |`RGB_RMOD`|Cycle through modes in reverse, forward direction when Shift is held |
  402. |`RGB_HUI` | |Increase hue, decrease hue when Shift is held |
  403. |`RGB_HUD` | |Decrease hue, increase hue when Shift is held |
  404. |`RGB_SAI` | |Increase saturation, decrease saturation when Shift is held |
  405. |`RGB_SAD` | |Decrease saturation, increase saturation when Shift is held |
  406. |`RGB_VAI` | |Increase value (brightness), decrease value when Shift is held |
  407. |`RGB_VAD` | |Decrease value (brightness), increase value when Shift is held |
  408. |`RGB_SPI` | |Increase effect speed (does not support eeprom yet), decrease speed when Shift is held|
  409. |`RGB_SPD` | |Decrease effect speed (does not support eeprom yet), increase speed when Shift is held|
  410. ## Thermal Printer :id=thermal-printer
  411. See also: [Thermal Printer](feature_thermal_printer.md)
  412. |Key |Description |
  413. |-----------|----------------------------------------|
  414. |`PRINT_ON` |Start printing everything the user types|
  415. |`PRINT_OFF`|Stop printing everything the user types |
  416. ## US ANSI Shifted Symbols :id=us-ansi-shifted-symbols
  417. See also: [US ANSI Shifted Symbols](keycodes_us_ansi_shifted.md)
  418. |Key |Aliases |Description|
  419. |------------------------|-------------------|-----------|
  420. |`KC_TILDE` |`KC_TILD` |`~` |
  421. |`KC_EXCLAIM` |`KC_EXLM` |`!` |
  422. |`KC_AT` | |`@` |
  423. |`KC_HASH` | |`#` |
  424. |`KC_DOLLAR` |`KC_DLR` |`$` |
  425. |`KC_PERCENT` |`KC_PERC` |`%` |
  426. |`KC_CIRCUMFLEX` |`KC_CIRC` |`^` |
  427. |`KC_AMPERSAND` |`KC_AMPR` |`&` |
  428. |`KC_ASTERISK` |`KC_ASTR` |`*` |
  429. |`KC_LEFT_PAREN` |`KC_LPRN` |`(` |
  430. |`KC_RIGHT_PAREN` |`KC_RPRN` |`)` |
  431. |`KC_UNDERSCORE` |`KC_UNDS` |`_` |
  432. |`KC_PLUS` | |`+` |
  433. |`KC_LEFT_CURLY_BRACE` |`KC_LCBR` |`{` |
  434. |`KC_RIGHT_CURLY_BRACE` |`KC_RCBR` |`}` |
  435. |`KC_PIPE` | |`\|` |
  436. |`KC_COLON` |`KC_COLN` |`:` |
  437. |`KC_DOUBLE_QUOTE` |`KC_DQUO`, `KC_DQT`|`"` |
  438. |`KC_LEFT_ANGLE_BRACKET` |`KC_LABK`, `KC_LT` |`<` |
  439. |`KC_RIGHT_ANGLE_BRACKET`|`KC_RABK`, `KC_GT` |`>` |
  440. |`KC_QUESTION` |`KC_QUES` |`?` |
  441. ## One Shot Keys :id=one-shot-keys
  442. See also: [One Shot Keys](one_shot_keys.md)
  443. |Key |Description |
  444. |------------|----------------------------------|
  445. |`OSM(mod)` |Hold `mod` for one keypress |
  446. |`OSL(layer)`|Switch to `layer` for one keypress|
  447. ## Space Cadet :id=space-cadet
  448. See also: [Space Cadet](feature_space_cadet.md)
  449. |Key |Description |
  450. |-----------|----------------------------------------|
  451. |`KC_LCPO` |Left Control when held, `(` when tapped |
  452. |`KC_RCPC` |Right Control when held, `)` when tapped|
  453. |`KC_LSPO` |Left Shift when held, `(` when tapped |
  454. |`KC_RSPC` |Right Shift when held, `)` when tapped |
  455. |`KC_LAPO` |Left Alt when held, `(` when tapped |
  456. |`KC_RAPC` |Right Alt when held, `)` when tapped |
  457. |`KC_SFTENT`|Right Shift when held, Enter when tapped|
  458. ## Swap Hands :id=swap-hands
  459. See also: [Swap Hands](feature_swap_hands.md)
  460. |Key |Description |
  461. |-----------|-------------------------------------------------------------------------|
  462. |`SH_T(key)`|Sends `key` with a tap; momentary swap when held. |
  463. |`SW_ON` |Turns on swapping and leaves it on. |
  464. |`SW_OFF` |Turn off swapping and leaves it off. Good for returning to a known state.|
  465. |`SH_MON` |Swaps hands when pressed, returns to normal when released (momentary). |
  466. |`SH_MOFF` |Momentarily turns off swap. |
  467. |`SH_TG` |Toggles swap on and off with every key press. |
  468. |`SH_TT` |Toggles with a tap; momentary when held. |
  469. |`SH_OS` |One shot swap hands: toggle while pressed or until next key press. |
  470. ## Unicode Support :id=unicode-support
  471. See also: [Unicode Support](feature_unicode.md)
  472. |Key |Aliases |Description |
  473. |----------------------|---------|----------------------------------------------------------------|
  474. |`UC(c)` | |Send Unicode code point `c` |
  475. |`X(i)` | |Send Unicode code point at index `i` in `unicode_map` |
  476. |`XP(i, j)` | |Send Unicode code point at index `i`, or `j` if Shift/Caps is on|
  477. |`UNICODE_MODE_FORWARD`|`UC_MOD` |Cycle through selected input modes |
  478. |`UNICODE_MODE_REVERSE`|`UC_RMOD`|Cycle through selected input modes in reverse |
  479. |`UNICODE_MODE_MAC` |`UC_M_MA`|Switch to macOS input |
  480. |`UNICODE_MODE_LNX` |`UC_M_LN`|Switch to Linux input |
  481. |`UNICODE_MODE_WIN` |`UC_M_WI`|Switch to Windows input |
  482. |`UNICODE_MODE_BSD` |`UC_M_BS`|Switch to BSD input (not implemented) |
  483. |`UNICODE_MODE_WINC` |`UC_M_WC`|Switch to Windows input using WinCompose |