]> git.donarmstrong.com Git - qmk_firmware.git/blob - docs/feature_rgblight.md
convert to unix line-endings [skip ci]
[qmk_firmware.git] / docs / feature_rgblight.md
1 # RGB Lighting
2
3 If you've installed addressable RGB lights on your keyboard you can control them with QMK. Currently we support the following addressable LEDs on Atmel AVR processors:
4
5 * WS2811 and variants (WS2812, WS2812B, WS2812C, etc)
6 * SK6812RGBW
7
8 Some keyboards come with RGB LEDs pre-installed. Others have to have LEDs installed after the fact. See below for information on modifying your keyboard.
9
10 ## Selecting Colors
11
12 QMK uses Hue, Saturation, and Value to set color rather than using RGB. You can use the color wheel below to see how this works. Changing the Hue will cycle around the circle. Saturation will affect the intensity of the color, which you can see as you move from the inner part to the outer part of the wheel. Value sets the overall brightness.
13
14 <img src="gitbook/images/color-wheel.svg" alt="HSV Color Wheel" width="250">
15
16 If you would like to learn more about HSV you can start with the [Wikipedia article](https://en.wikipedia.org/wiki/HSL_and_HSV).
17
18 ## Configuration
19
20 Before RGB Lighting can be used you have to enable it in `rules.mk`:
21
22     RGBLIGHT_ENABLE = yes
23
24 You can configure the behavior of the RGB lighting by defining values inside `config.h`.
25
26 ### Required Configuration
27
28 At minimum you have to define the pin your LED strip is connected to and the number of LEDs connected.
29
30 ```c
31 #define RGB_DI_PIN D7     // The pin the LED strip is connected to
32 #define RGBLED_NUM 14     // Number of LEDs in your strip
33 ```
34
35 ### Optional Configuration
36
37 You can change the behavior of the RGB Lighting by setting these configuration values. Use `#define <Option> <Value>` in a `config.h` at the keyboard, revision, or keymap level.
38
39 | Option | Default Value | Description |
40 |--------|---------------|-------------|
41 | `RGBLIGHT_HUE_STEP` | 10 | How many hues you want to have available. |
42 | `RGBLIGHT_SAT_STEP` | 17 | How many steps of saturation you'd like. |
43 | `RGBLIGHT_VAL_STEP` | 17 | The number of levels of brightness you want. |
44
45 ### Animations
46
47 If you have `#define RGBLIGHT_ANIMATIONS` in your `config.h` you will have a number of animation modes you can cycle through using the `RGB_MOD` key. You can also `#define` other options to tweak certain animations.
48
49 | Option | Default Value | Description |
50 |--------|---------------|-------------|
51 | `RGBLIGHT_ANIMATIONS` | | `#define` this to enable animation modes. |
52 | `RGBLIGHT_EFFECT_BREATHE_CENTER` | 1.85 | Used to calculate the curve for the breathing animation. Valid values 1.0-2.7. |
53 | `RGBLIGHT_EFFECT_BREATHE_MAX` | 255 | The maximum brightness for the breathing mode. Valid values 1-255. |
54 | `RGBLIGHT_EFFECT_SNAKE_LENGTH` | 4 | The number of LEDs to light up for the "snake" animation. |
55 | `RGBLIGHT_EFFECT_KNIGHT_LENGTH` | 3 | The number of LEDs to light up for the "knight" animation. |
56 | `RGBLIGHT_EFFECT_KNIGHT_OFFSET` | 0 | Start the knight animation this many LEDs from the start of the strip. |
57 | `RGBLIGHT_EFFECT_KNIGHT_LED_NUM` | RGBLED_NUM | The number of LEDs to have the "knight" animation travel. |
58 | `RGBLIGHT_EFFECT_CHRISTMAS_INTERVAL` | 1000 | How long to wait between light changes for the "christmas" animation. Specified in ms. |
59 | `RGBLIGHT_EFFECT_CHRISTMAS_STEP` | 2 | How many LED's to group the red/green colors by for the christmas mode. |
60
61 You can also tweak the behavior of the animations by defining these consts in your `keymap.c`. These mostly affect the speed different modes animate at.
62
63 ```c
64 // How long (in ms) to wait between animation steps for the breathing mode
65 const uint8_t RGBLED_BREATHING_INTERVALS[] PROGMEM = {30, 20, 10, 5};
66
67 // How long (in ms) to wait between animation steps for the rainbow mode
68 const uint8_t RGBLED_RAINBOW_MOOD_INTERVALS[] PROGMEM = {120, 60, 30};
69
70 // How long (in ms) to wait between animation steps for the swirl mode
71 const uint8_t RGBLED_RAINBOW_SWIRL_INTERVALS[] PROGMEM = {100, 50, 20};
72
73 // How long (in ms) to wait between animation steps for the snake mode
74 const uint8_t RGBLED_SNAKE_INTERVALS[] PROGMEM = {100, 50, 20};
75
76 // How long (in ms) to wait between animation steps for the knight modes
77 const uint8_t RGBLED_KNIGHT_INTERVALS[] PROGMEM = {127, 63, 31};
78
79 // These control which colors are selected for the gradient mode
80 const uint16_t RGBLED_GRADIENT_RANGES[] PROGMEM = {360, 240, 180, 120, 90};
81 ```
82
83 ## RGB Lighting Keycodes
84
85 These control the RGB Lighting functionality.
86
87 | Long Name | Short Name | Description |
88 |-----------|------------|-------------|
89 ||`RGB_TOG`|toggle on/off|
90 ||`RGB_MOD`|cycle through modes|
91 ||`RGB_SMOD`|cycle through modes, use reverse direction when shift is hold|
92 ||`RGB_HUI`|hue increase|
93 ||`RGB_HUD`|hue decrease|
94 ||`RGB_SAI`|saturation increase|
95 ||`RGB_SAD`|saturation decrease|
96 ||`RGB_VAI`|value (brightness) increase|
97 ||`RGB_VAD`|value (brightness) decrease|
98 |`RGB_MODE_PLAIN`|`RGB_M_P `| Switch to the static no animation mode |
99 |`RGB_MODE_BREATHE`|`RGB_M_B`| Switch to the breathing mode |
100 |`RGB_MODE_RAINBOW`|`RGB_M_R`| Switch to the rainbow mode ||
101 |`RGB_MODE_SWIRL`|`RGB_M_SW`| Switch to the swirl mode |
102 |`RGB_MODE_SNAKE`|`RGB_M_SN`| Switch to the snake mode |
103 |`RGB_MODE_KNIGHT`|`RGB_M_K`| Switch to the knight animation |
104 |`RGB_MODE_XMAS`|`RGB_M_X`| Switch to the Christmas animation |
105 |`RGB_MODE_GRADIENT`|`RGB_M_G`| Switch to the static gradient mode |
106
107 ## Hardware Modification
108
109 ![Planck with RGB Underglow](https://raw.githubusercontent.com/qmk/qmk_firmware/master/keyboards/planck/keymaps/yang/planck-with-rgb-underglow.jpg)
110
111 Here is a quick demo on Youtube (with NPKC KC60) (https://www.youtube.com/watch?v=VKrpPAHlisY).
112
113 For this mod, you need an unused pin wiring to DI of WS2812 strip. After wiring the VCC, GND, and DI, you can enable the underglow in your Makefile.
114
115     RGBLIGHT_ENABLE = yes
116
117 In order to use the underglow animation functions, you need to have `#define RGBLIGHT_ANIMATIONS` in your `config.h`.
118
119 Please add the following options into your config.h, and set them up according your hardware configuration. These settings are for the `F4` pin by default:
120
121     #define RGB_DI_PIN F4     // The pin your RGB strip is wired to
122     #define RGBLED_NUM 14     // Number of LEDs
123
124 You'll need to edit `RGB_DI_PIN` to the pin you have your `DI` on your RGB strip wired to.