X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=docs%2Ffeature_rgblight.md;h=e0918d11bdd2e245154ce36b6d934991989bb00e;hb=5229734647706054066c277ea348a6d25cc38095;hp=7f12155cb703d1aa6beee80579671568d7a9f840;hpb=a6845036e25c4f4d936dcd12cd0ddedd2894b30e;p=qmk_firmware.git diff --git a/docs/feature_rgblight.md b/docs/feature_rgblight.md index 7f12155cb..e0918d11b 100644 --- a/docs/feature_rgblight.md +++ b/docs/feature_rgblight.md @@ -1,49 +1,170 @@ # RGB Lighting - +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: -## RGB Under Glow Mod +* WS2811 and variants (WS2812, WS2812B, WS2812C, etc) +* SK6812RGBW -![Planck with RGB Underglow](https://raw.githubusercontent.com/qmk/qmk_firmware/master/keyboards/planck/keymaps/yang/planck-with-rgb-underglow.jpg) +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. -Here is a quick demo on Youtube (with NPKC KC60) (https://www.youtube.com/watch?v=VKrpPAHlisY). +## Selecting Colors -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. +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. + +HSV Color Wheel + +If you would like to learn more about HSV you can start with the [Wikipedia article](https://en.wikipedia.org/wiki/HSL_and_HSV). + +## Configuration + +Before RGB Lighting can be used you have to enable it in `rules.mk`: RGBLIGHT_ENABLE = yes -In order to use the underglow animation functions, you need to have `#define RGBLIGHT_ANIMATIONS` in your `config.h`. +You can configure the behavior of the RGB lighting by defining values inside `config.h`. -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: +### Required Configuration - #define RGB_DI_PIN F4 // The pin your RGB strip is wired to - #define RGBLIGHT_ANIMATIONS // Require for fancier stuff (not compatible with audio) - #define RGBLED_NUM 14 // Number of LEDs - #define RGBLIGHT_HUE_STEP 10 - #define RGBLIGHT_SAT_STEP 17 - #define RGBLIGHT_VAL_STEP 17 +At minimum you have to define the pin your LED strip is connected to and the number of LEDs connected. -You'll need to edit `RGB_DI_PIN` to the pin you have your `DI` on your RGB strip wired to. +```c +#define RGB_DI_PIN D7 // The pin the LED strip is connected to +#define RGBLED_NUM 14 // Number of LEDs in your strip +``` + +### Optional Configuration + +You can change the behavior of the RGB Lighting by setting these configuration values. Use `#define