keyboard stuff
at master 122 lines 5.1 kB view raw view rendered
1# LED Indicators 2 3::: tip 4LED indicators on split keyboards will require state information synced to the slave half (e.g. `#define SPLIT_LED_STATE_ENABLE`). See [data sync options](split_keyboard#data-sync-options) for more details. 5::: 6 7QMK provides methods to read 5 of the LEDs defined in the HID spec: 8 9* Num Lock 10* Caps Lock 11* Scroll Lock 12* Compose 13* Kana 14 15There are three ways to get the lock LED state: 16* Configuration options in `config.h` 17* Implement `led_update_*` function 18* Call `led_t host_keyboard_led_state()` 19 20::: warning 21The `host_keyboard_led_state()` may reflect an updated state before `led_update_user()` is called. 22::: 23 24Deprecated functions that provide the LED state as `uint8_t`: 25 26* `uint8_t host_keyboard_leds()` 27 28## Configuration Options 29 30To configure the indicators, `#define` these in your `config.h`: 31 32|Define |Default |Description | 33|---------------------|-------------|-------------------------------------------| 34|`LED_NUM_LOCK_PIN` |*Not defined*|The pin that controls the `Num Lock` LED | 35|`LED_CAPS_LOCK_PIN` |*Not defined*|The pin that controls the `Caps Lock` LED | 36|`LED_SCROLL_LOCK_PIN`|*Not defined*|The pin that controls the `Scroll Lock` LED| 37|`LED_COMPOSE_PIN` |*Not defined*|The pin that controls the `Compose` LED | 38|`LED_KANA_PIN` |*Not defined*|The pin that controls the `Kana` LED | 39|`LED_PIN_ON_STATE` |`1` |The state of the indicator pins when the LED is "on" - `1` for high, `0` for low| 40 41Unless you are designing your own keyboard, you generally should not need to change the above config options. 42 43## LED update function 44 45When 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: 46 47* Keyboard/revision: `bool led_update_kb(led_t led_state)` 48* Keymap: `bool led_update_user(led_t led_state)` 49 50Both 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. 51 52### Example of keyboard LED update implementation 53 54This is a template indicator function that can be implemented on keyboard level code: 55 56```c 57bool led_update_kb(led_t led_state) { 58 bool res = led_update_user(led_state); 59 if(res) { 60 // gpio_write_pin sets the pin high for 1 and low for 0. 61 // In this example the pins are inverted, setting 62 // it low/0 turns it on, and high/1 turns the LED off. 63 // This behavior depends on whether the LED is between the pin 64 // and VCC or the pin and GND. 65 gpio_write_pin(B0, !led_state.num_lock); 66 gpio_write_pin(B1, !led_state.caps_lock); 67 gpio_write_pin(B2, !led_state.scroll_lock); 68 gpio_write_pin(B3, !led_state.compose); 69 gpio_write_pin(B4, !led_state.kana); 70 } 71 return res; 72} 73``` 74 75### Example of user LED update implementation 76 77This 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. 78 79```c 80#ifdef AUDIO_ENABLE 81 float caps_on[][2] = SONG(CAPS_LOCK_ON_SOUND); 82 float caps_off[][2] = SONG(CAPS_LOCK_OFF_SOUND); 83#endif 84 85bool led_update_user(led_t led_state) { 86 #ifdef AUDIO_ENABLE 87 static uint8_t caps_state = 0; 88 if (caps_state != led_state.caps_lock) { 89 led_state.caps_lock ? PLAY_SONG(caps_on) : PLAY_SONG(caps_off); 90 caps_state = led_state.caps_lock; 91 } 92 #endif 93 return true; 94} 95``` 96 97## Host keyboard LED state 98 99The `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: 100 101```c 102bool caps = host_keyboard_led_state().caps_lock; 103``` 104 105## `led_update_ports()` 106 107This function writes the LED state to the actual hardware. Call it manually 108from your `led_update_*()` callbacks to modify the handling of the standard 109keyboard LEDs. 110For example when repurposing a standard LED indicator as layer indicator. 111 112## Setting Physical LED State 113 114Some keyboard implementations provide convenient methods for setting the state of the physical LEDs. 115 116### Ergodox Boards 117 118The 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. 119 120In 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)`. 121 122Ergodox boards also define `LED_BRIGHTNESS_LO` for the lowest brightness and `LED_BRIGHTNESS_HI` for the highest brightness (which is the default).