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.

121 lines
5.1 KiB

  1. # LED Indicators
  2. ?> LED indicators on split keyboards will require state information synced to the slave half (e.g. `#define SPLIT_LED_STATE_ENABLE`). See [data sync options](feature_split_keyboard.md#data-sync-options) for more details.
  3. QMK provides methods to read 5 of the LEDs defined in the HID spec:
  4. * Num Lock
  5. * Caps Lock
  6. * Scroll Lock
  7. * Compose
  8. * Kana
  9. There are three ways to get the lock LED state:
  10. * Configuration options in `config.h`
  11. * Implement `led_update_*` function
  12. * Call `led_t host_keyboard_led_state()`
  13. !> The `host_keyboard_led_state()` may reflect an updated state before `led_update_user()` is called.
  14. Two deprecated functions that provide the LED state as `uint8_t`:
  15. * `uint8_t led_set_user(uint8_t usb_led)`
  16. * `uint8_t host_keyboard_leds()`
  17. ## Configuration Options
  18. To configure the indicators, `#define` these in your `config.h`:
  19. |Define |Default |Description |
  20. |---------------------|-------------|-------------------------------------------|
  21. |`LED_NUM_LOCK_PIN` |*Not defined*|The pin that controls the `Num Lock` LED |
  22. |`LED_CAPS_LOCK_PIN` |*Not defined*|The pin that controls the `Caps Lock` LED |
  23. |`LED_SCROLL_LOCK_PIN`|*Not defined*|The pin that controls the `Scroll Lock` LED|
  24. |`LED_COMPOSE_PIN` |*Not defined*|The pin that controls the `Compose` LED |
  25. |`LED_KANA_PIN` |*Not defined*|The pin that controls the `Kana` LED |
  26. |`LED_PIN_ON_STATE` |`1` |The state of the indicator pins when the LED is "on" - `1` for high, `0` for low|
  27. Unless you are designing your own keyboard, you generally should not need to change the above config options.
  28. ## LED update function
  29. When the configuration options do not provide enough flexibility, the following callbacks allow custom control of the LED behavior. These functions will be called when one of those 5 LEDs changes state:
  30. * Keyboard/revision: `bool led_update_kb(led_t led_state)`
  31. * Keymap: `bool led_update_user(led_t led_state)`
  32. Both receives LED state as a struct parameter. Returning `true` in `led_update_user()` will allow the keyboard level code in `led_update_kb()` to run as well. Returning `false` will override the keyboard level code, depending on how the keyboard level function is set up.
  33. ?> This boolean return type of `led_update_user` allows for overriding keyboard LED controls, and is thus recommended over the void `led_set_user` function.
  34. ### Example of keyboard LED update implementation
  35. This is a template indicator function that can be implemented on keyboard level code:
  36. ```c
  37. bool led_update_kb(led_t led_state) {
  38. bool res = led_update_user(led_state);
  39. if(res) {
  40. // gpio_write_pin sets the pin high for 1 and low for 0.
  41. // In this example the pins are inverted, setting
  42. // it low/0 turns it on, and high/1 turns the LED off.
  43. // This behavior depends on whether the LED is between the pin
  44. // and VCC or the pin and GND.
  45. gpio_write_pin(B0, !led_state.num_lock);
  46. gpio_write_pin(B1, !led_state.caps_lock);
  47. gpio_write_pin(B2, !led_state.scroll_lock);
  48. gpio_write_pin(B3, !led_state.compose);
  49. gpio_write_pin(B4, !led_state.kana);
  50. }
  51. return res;
  52. }
  53. ```
  54. ### Example of user LED update implementation
  55. This is an incomplete example will play a sound if Caps Lock is turned on or off. It returns `true` to allow keyboard LED function to maintain their state.
  56. ```c
  57. #ifdef AUDIO_ENABLE
  58. float caps_on[][2] = SONG(CAPS_LOCK_ON_SOUND);
  59. float caps_off[][2] = SONG(CAPS_LOCK_OFF_SOUND);
  60. #endif
  61. bool led_update_user(led_t led_state) {
  62. #ifdef AUDIO_ENABLE
  63. static uint8_t caps_state = 0;
  64. if (caps_state != led_state.caps_lock) {
  65. led_state.caps_lock ? PLAY_SONG(caps_on) : PLAY_SONG(caps_off);
  66. caps_state = led_state.caps_lock;
  67. }
  68. #endif
  69. return true;
  70. }
  71. ```
  72. ## Host keyboard LED state
  73. The `host_keyboard_led_state()` function will report the LED state returned from the host computer as `led_t`. This is useful for reading the LED state outside `led_update_*`. For example, you can get the boolean state of Caps Lock from the host with:
  74. ```c
  75. bool caps = host_keyboard_led_state().caps_lock;
  76. ```
  77. ## `led_update_ports()`
  78. This function writes the LED state to the actual hardware. Call it manually
  79. from your `led_update_*()` callbacks to modify the handling of the standard
  80. keyboard LEDs.
  81. For example when repurposing a standard LED indicator as layer indicator.
  82. ## Setting Physical LED State
  83. Some keyboard implementations provide convenient methods for setting the state of the physical LEDs.
  84. ### Ergodox Boards
  85. The Ergodox implementations provide `ergodox_right_led_1`/`2`/`3_on`/`off()` to turn individual LEDs on or off, as well as `ergodox_right_led_on`/`off(uint8_t led)` to turn them on or off by their index.
  86. In addition, it is possible to specify the brightness level of all LEDs with `ergodox_led_all_set(uint8_t n)`; of individual LEDs with `ergodox_right_led_1`/`2`/`3_set(uint8_t n)`; or by index with `ergodox_right_led_set(uint8_t led, uint8_t n)`.
  87. Ergodox boards also define `LED_BRIGHTNESS_LO` for the lowest brightness and `LED_BRIGHTNESS_HI` for the highest brightness (which is the default).