APA102 Driver
This driver provides support for APA102 addressable RGB LEDs. They are similar to the WS2812 LEDs, but have increased data and refresh rates.
Usage
In most cases, the APA102 driver code is automatically included if you are using either the RGBLight or RGB Matrix feature with the apa102
driver set, and you would use those APIs instead.
However, if you need to use the driver standalone, add the following to your rules.mk
:
APA102_DRIVER_REQUIRED = yes
You can then call the APA102 API by including apa102.h
in your code.
Basic Configuration
Add the following to your config.h
:
Define | Default | Description |
---|---|---|
APA102_DI_PIN | Not defined | The GPIO pin connected to the DI pin of the first LED in the chain |
APA102_CI_PIN | Not defined | The GPIO pin connected to the CI pin of the first LED in the chain |
APA102_DEFAULT_BRIGHTNESS | 31 | The default global brightness level of the LEDs, from 0 to 31 |
API
void apa102_init(void)
Initialize the LED driver. This function should be called first.
void apa102_set_color(uint16_t index, uint8_t red, uint8_t green, uint8_t blue)
Set the color of a single LED. This function does not immediately update the LEDs; call apa102_flush()
after you are finished.
Arguments
uint16_t index
The LED index in the APA102 chain.uint8_t red
The red value to set.uint8_t green
The green value to set.uint8_t blue
The blue value to set.
void apa102_set_color_all(uint8_t red, uint8_t green, uint8_t blue)
Set the color of all LEDs.
Arguments
uint8_t red
The red value to set.uint8_t green
The green value to set.uint8_t blue
The blue value to set.
void apa102_flush(void)
Flush the PWM values to the LED chain.
void apa102_set_brightness(uint8_t brightness)
Set the global brightness.
Arguments
uint8_t brightness
The brightness level to set, from 0 to 31.