2#ifndef __INC_FASTSPI_LED2_H
3#define __INC_FASTSPI_LED2_H
10#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4)
11#define FASTLED_HAS_PRAGMA_MESSAGE
19#define FASTLED_VERSION 3009003
20#ifndef FASTLED_INTERNAL
21# ifdef FASTLED_SHOW_VERSION
22# ifdef FASTLED_HAS_PRAGMA_MESSAGE
23# pragma message "FastLED version 3.009.003"
25# warning FastLED version 3.009.003 (Not really a warning, just telling you here.)
30#ifndef __PROG_TYPES_COMPAT__
34#define __PROG_TYPES_COMPAT__
38#include <SmartMatrix.h>
50#include <OctoWS2811.h>
55#include "force_inline.h"
74#include "pixeltypes.h"
85#include "engine_events.h"
87FASTLED_NAMESPACE_BEGIN
115enum OWS2811 { OCTOWS2811,OCTOWS2811_400, OCTOWS2813};
123template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
class PIXIE :
public PixieController<DATA_PIN, RGB_ORDER> {};
126#ifdef FASTLED_HAS_CLOCKLESS
138template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
143template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
148template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
153template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
158template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
163template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
168template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
173template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
178template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
183template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
188template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
192template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
197template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
202template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
207template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
212template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
217template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
222template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
227template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
232template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
237template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
242template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
247template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
252template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
257template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
262template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
267template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
272template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
276template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
279#if defined(DmxSimple_h) || defined(FASTLED_DOXYGEN)
283#if defined(DmxSerial_h) || defined(FASTLED_DOXYGEN)
294#ifdef PORTA_FIRST_PIN
301#ifdef PORTB_FIRST_PIN
308#ifdef PORTC_FIRST_PIN
315#ifdef PORTD_FIRST_PIN
331#if defined(LIB8_ATTINY)
332#define NUM_CONTROLLERS 2
336#define NUM_CONTROLLERS 8
357 uint32_t m_nMinMicros;
358 uint32_t m_nPowerData;
404 template<ESPIChipsets CHIPSET, u
int8_t DATA_PIN, u
int8_t CLOCK_PIN>
407 static const bool IS_VALID =
false;
412 #define _FL_MAP_CLOCKED_CHIPSET(CHIPSET_ENUM, CONTROLLER_CLASS) \
413 template<uint8_t DATA_PIN, uint8_t CLOCK_PIN> \
414 struct ClockedChipsetHelper<CHIPSET_ENUM, DATA_PIN, CLOCK_PIN> { \
415 static const bool IS_VALID = true; \
416 typedef CONTROLLER_CLASS<DATA_PIN, CLOCK_PIN> ControllerType; \
418 template<EOrder RGB_ORDER> \
419 struct CONTROLLER_CLASS_WITH_ORDER { \
420 typedef CONTROLLER_CLASS<DATA_PIN, CLOCK_PIN, RGB_ORDER> ControllerType; \
423 template<EOrder RGB_ORDER, uint32_t FREQ> \
424 struct CONTROLLER_CLASS_WITH_ORDER_AND_FREQ { \
425 typedef CONTROLLER_CLASS<DATA_PIN, CLOCK_PIN, RGB_ORDER, FREQ> ControllerType; \
450 template<
ESPIChipsets CHIPSET, uint8_t DATA_PIN, uint8_t CLOCK_PIN, EOrder RGB_ORDER, uint32_t SPI_DATA_RATE >
CLEDController &
addLeds(struct
CRGB *data,
int nLedsOrOffset,
int nLedsIfOffset = 0) {
453 typedef typename CHIP::template CONTROLLER_CLASS_WITH_ORDER_AND_FREQ<RGB_ORDER, SPI_DATA_RATE>::ControllerType ControllerTypeWithFreq;
454 static_assert(CHIP::IS_VALID,
"Unsupported chipset");
455 static ControllerTypeWithFreq c;
456 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
460 template<ESPIChipsets CHIPSET, u
int8_t DATA_PIN, u
int8_t CLOCK_PIN >
static CLEDController &
addLeds(
struct CRGB *data,
int nLedsOrOffset,
int nLedsIfOffset = 0) {
462 typedef typename CHIP::ControllerType ControllerType;
463 static_assert(CHIP::IS_VALID,
"Unsupported chipset");
464 static ControllerType c;
465 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
470 template<ESPIChipsets CHIPSET, u
int8_t DATA_PIN, u
int8_t CLOCK_PIN, EOrder RGB_ORDER>
472 typedef ClockedChipsetHelper<CHIPSET, DATA_PIN, CLOCK_PIN> CHIP;
473 static_assert(CHIP::IS_VALID,
"Unsupported chipset");
474 typedef typename CHIP::template CONTROLLER_CLASS_WITH_ORDER<RGB_ORDER>::ControllerType ControllerTypeWithOrder;
475 static ControllerTypeWithOrder c;
476 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
481 template<ESPIChipsets CHIPSET>
static CLEDController &
addLeds(
struct CRGB *data,
int nLedsOrOffset,
int nLedsIfOffset = 0) {
485 template<ESPIChipsets CHIPSET, EOrder RGB_ORDER>
static CLEDController &
addLeds(
struct CRGB *data,
int nLedsOrOffset,
int nLedsIfOffset = 0) {
489 template<ESPIChipsets CHIPSET, EOrder RGB_ORDER, u
int32_t SPI_DATA_RATE>
static CLEDController &
addLeds(
struct CRGB *data,
int nLedsOrOffset,
int nLedsIfOffset = 0) {
496#ifdef FASTLED_HAS_CLOCKLESS
519 template<
template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
class CHIPSET, uint8_t DATA_PIN, EOrder RGB_ORDER>
521 static CHIPSET<DATA_PIN, RGB_ORDER> c;
522 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
526 template<
template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
class CHIPSET, uint8_t DATA_PIN>
528 static CHIPSET<DATA_PIN, RGB> c;
529 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
533 template<
template<u
int8_t DATA_PIN>
class CHIPSET, uint8_t DATA_PIN>
535 static CHIPSET<DATA_PIN> c;
536 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
539#if defined(__FASTLED_HAS_FIBCC) && (__FASTLED_HAS_FIBCC == 1)
540 template<u
int8_t NUM_LANES,
template<u
int8_t DATA_PIN, EOrder RGB_ORDER>
class CHIPSET, uint8_t DATA_PIN, EOrder RGB_ORDER=RGB>
542 static __FIBCC<CHIPSET, DATA_PIN, NUM_LANES, RGB_ORDER> c;
543 return addLeds(&c, data, nLeds);
547 #ifdef FASTSPI_USE_DMX_SIMPLE
548 template<EClocklessChipsets CHIPSET, u
int8_t DATA_PIN, EOrder RGB_ORDER=RGB>
552 case DMX: {
static DMXController<DATA_PIN> controller;
return addLeds(&controller, data, nLedsOrOffset, nLedsIfOffset); }
581 template<
template<EOrder RGB_ORDER>
class CHIPSET, EOrder RGB_ORDER>
583 static CHIPSET<RGB_ORDER> c;
584 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
588 template<
template<EOrder RGB_ORDER>
class CHIPSET>
590 static CHIPSET<RGB> c;
591 return addLeds(&c, data, nLedsOrOffset, nLedsIfOffset);
598 template<OWS2811 CHIPSET, EOrder RGB_ORDER>
602 case OCTOWS2811: {
static COctoWS2811Controller<RGB_ORDER,WS2811_800kHz> controller;
return addLeds(&controller, data, nLedsOrOffset, nLedsIfOffset); }
603 case OCTOWS2811_400: {
static COctoWS2811Controller<RGB_ORDER,WS2811_400kHz> controller;
return addLeds(&controller, data, nLedsOrOffset, nLedsIfOffset); }
605 case OCTOWS2813: {
static COctoWS2811Controller<RGB_ORDER,WS2813_800kHz> controller;
return addLeds(&controller, data, nLedsOrOffset, nLedsIfOffset); }
613 template<OWS2811 CHIPSET>
621#ifdef USE_WS2812SERIAL
625 template<SWS2812 CHIPSET,
int DATA_PIN, EOrder RGB_ORDER>
628 static CWS2812SerialController<DATA_PIN,RGB_ORDER> controller;
629 return addLeds(&controller, data, nLedsOrOffset, nLedsIfOffset);
636 template<ESM CHIPSET>
640 case SMART_MATRIX: {
static CSmartMatrixController controller;
return addLeds(&controller, data, nLedsOrOffset, nLedsIfOffset); }
647#ifdef FASTLED_HAS_BLOCKLESS
671 template<EBlockChipsets CHIPSET,
int NUM_LANES, EOrder RGB_ORDER>
674 #ifdef PORTA_FIRST_PIN
675 case WS2811_PORTA:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTA_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
676 case WS2811_400_PORTA:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTA_FIRST_PIN,
NS(800),
NS(800),
NS(900), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
677 case WS2813_PORTA:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTA_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER, 0,
false, 300>(), data, nLedsOrOffset, nLedsIfOffset);
678 case TM1803_PORTA:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTA_FIRST_PIN,
NS(700),
NS(1100),
NS(700), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
679 case UCS1903_PORTA:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTA_FIRST_PIN,
NS(500),
NS(1500),
NS(500), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
681 #ifdef PORTB_FIRST_PIN
682 case WS2811_PORTB:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTB_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
683 case WS2811_400_PORTB:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTB_FIRST_PIN,
NS(800),
NS(800),
NS(900), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
684 case WS2813_PORTB:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTB_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER, 0,
false, 300>(), data, nLedsOrOffset, nLedsIfOffset);
685 case TM1803_PORTB:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTB_FIRST_PIN,
NS(700),
NS(1100),
NS(700), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
686 case UCS1903_PORTB:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTB_FIRST_PIN,
NS(500),
NS(1500),
NS(500), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
688 #ifdef PORTC_FIRST_PIN
689 case WS2811_PORTC:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTC_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
690 case WS2811_400_PORTC:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTC_FIRST_PIN,
NS(800),
NS(800),
NS(900), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
691 case WS2813_PORTC:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTC_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER, 0,
false, 300>(), data, nLedsOrOffset, nLedsIfOffset);
692 case TM1803_PORTC:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTC_FIRST_PIN,
NS(700),
NS(1100),
NS(700), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
693 case UCS1903_PORTC:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTC_FIRST_PIN,
NS(500),
NS(1500),
NS(500), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
695 #ifdef PORTD_FIRST_PIN
696 case WS2811_PORTD:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTD_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
697 case WS2811_400_PORTD:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTD_FIRST_PIN,
NS(800),
NS(800),
NS(900), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
698 case WS2813_PORTD:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTD_FIRST_PIN,
NS(320),
NS(320),
NS(640), RGB_ORDER, 0,
false, 300>(), data, nLedsOrOffset, nLedsIfOffset);
699 case TM1803_PORTD:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTD_FIRST_PIN,
NS(700),
NS(1100),
NS(700), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
700 case UCS1903_PORTD:
return addLeds(
new InlineBlockClocklessController<NUM_LANES, PORTD_FIRST_PIN,
NS(500),
NS(1500),
NS(500), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
703 case WS2811_PORTDC:
return addLeds(
new SixteenWayInlineBlockClocklessController<NUM_LANES,
NS(320),
NS(320),
NS(640), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
704 case WS2811_400_PORTDC:
return addLeds(
new SixteenWayInlineBlockClocklessController<NUM_LANES,
NS(800),
NS(800),
NS(900), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
705 case WS2813_PORTDC:
return addLeds(
new SixteenWayInlineBlockClocklessController<NUM_LANES,
NS(320),
NS(320),
NS(640), RGB_ORDER, 0,
false, 300>(), data, nLedsOrOffset, nLedsIfOffset);
706 case TM1803_PORTDC:
return addLeds(
new SixteenWayInlineBlockClocklessController<NUM_LANES,
NS(700),
NS(1100),
NS(700), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
707 case UCS1903_PORTDC:
return addLeds(
new SixteenWayInlineBlockClocklessController<NUM_LANES,
NS(500),
NS(1500),
NS(500), RGB_ORDER>(), data, nLedsOrOffset, nLedsIfOffset);
713 template<EBlockChipsets CHIPSET,
int NUM_LANES>
739 void show(uint8_t scale);
747 void clear(
bool writeData =
false);
765 void delay(
unsigned long ms);
780 void setDither(uint8_t ditherMode = BINARY_DITHER);
819#define FastSPI_LED FastLED
821#define FastSPI_LED2 FastLED
833#ifndef HAS_HARDWARE_PIN_SUPPORT
834#warning "No pin/port mappings found, pin access will be slightly slower. See fastpin.h for info."
835#define NO_HARDWARE_PIN_SUPPORT
843#if !defined(FASTLED_INTERNAL)
844FASTLED_USING_NAMESPACE
SWS2812
WS2812Serial Library controller type.
OWS2811
Octo WS2811 LED Library controller types.
CFastLED FastLED
Global LED strip management instance.
uint8_t(* power_func)(uint8_t scale, uint32_t data)
Typedef for a power consumption calculation function.
ESPIChipsets
LED chipsets with SPI interface.
@ APA102HD
APA102 LED chipset with 5-bit gamma correction.
@ P9813
P9813 LED chipset.
@ SK9822HD
SK9822 LED chipset with 5-bit gamma correction.
@ SK9822
SK9822 LED chipset.
@ WS2803
WS2803 LED chipset.
@ WS2801
WS2801 LED chipset.
@ DOTSTAR
APA102 LED chipset alias.
@ APA102
APA102 LED chipset.
@ LPD8806
LPD8806 LED chipset.
@ LPD6803
LPD6803 LED chipset.
@ DOTSTARHD
APA102HD LED chipset alias.
@ SM16716
SM16716 LED chipset.
ESM
Smart Matrix Library controller type.
EBlockChipsets
Blockless output port enum.
Functions for doing a rotation of bits/bytes used by parallel output.
Contains the bulk of the definitions for the various LED chipsets supported.
APA102 high definition controller class.
High level controller interface for FastLED.
int size()
Get the number of leds in the first controller.
void setMaxRefreshRate(uint16_t refresh, bool constrain=false)
Set the maximum refresh rate.
CRGB * leds()
Get a pointer to led data for the first controller.
void setTemperature(const struct CRGB &temp)
Set a global color temperature.
static CLEDController & addLeds(struct CRGB *data, int nLedsOrOffset, int nLedsIfOffset=0)
Add an SPI based CLEDController instance to the world.
void show()
Update all our controllers with the current led colors.
void showColor(const struct CRGB &color)
Set all leds on all controllers to the given color.
void countFPS(int nFrames=25)
For debugging, this will keep track of time between calls to countFPS().
CLEDController & operator[](int x)
Get a reference to a registered controller.
void delay(unsigned long ms)
Delay for the given number of milliseconds.
void setBrightness(uint8_t scale)
Set the global brightness scaling.
void showColor(const struct CRGB &color, uint8_t scale)
Set all leds on all controllers to the given color/scale.
void setDither(uint8_t ditherMode=BINARY_DITHER)
Set the dithering mode.
void setMaxPowerInVoltsAndMilliamps(uint8_t volts, uint32_t milliamps)
Set the maximum power to be used, given in volts and milliamps.
uint16_t getFPS()
Get the number of frames/second being written out.
void setMaxPowerInMilliWatts(uint32_t milliwatts)
Set the maximum power to be used, given in milliwatts.
uint8_t getBrightness()
Get the current global brightness setting.
void clearData()
Clear out the local data array.
void setCorrection(const struct CRGB &correction)
Set a global color correction.
int count()
Get how many controllers have been registered.
static CLEDController & addLeds(struct CRGB *data, int nLedsOrOffset, int nLedsIfOffset=0)
Add a 3rd party library based CLEDController instance to the world.
void clear(bool writeData=false)
Clear the leds, wiping the local array of data.
static CLEDController & addLeds(struct CRGB *data, int nLedsOrOffset, int nLedsIfOffset=0)
Add a clockless based CLEDController instance to the world.
static CLEDController & addLeds(CLEDController *pLed, struct CRGB *data, int nLedsOrOffset, int nLedsIfOffset=0)
Add a CLEDController instance to the world.
Base definition for an LED controller.
DMX512 based LED controller class, using the DMXSerial library.
DMX512 based LED controller class, using the DmxSimple library.
DMX512 based LED controller class, using the DMXSerial library.
DMX512 based LED controller class, using the DmxSimple library.
GW6205_400 controller class.
GW6205 controller class @ 400 KHz.
UCS1904 controller class @ 800 KHz.
LPD1886_8BIT controller class.
LPD1886 controller class.
LPD1886 controller class.
LPD1886 controller class.
LPD6803 controller class (LPD1101).
LPD8806 controller class.
LED controller for WS2812 LEDs with GRB color order.
SM16703 controller class.
SM16703 controller class.
SM16716 controller class.
UCS1903B controller class.
UCS1903B controller class.
UCS1903 controller class @ 400 KHz.
UCS1903 controller class.
UCS1904 controller class.
UCS1904 controller class.
UCS1912 controller class.
UCS2903 controller class.
UCS2903 controller class.
WS2811_400 controller class.
WS2811 controller class @ 400 KHz.
WS2811 controller class @ 800 KHz.
WS2812B controller class.
WS2812 controller class @ 800 KHz.
WS2815 controller class @ 400 KHz.
Declarations for the predefined color palettes supplied by FastLED.
Utility functions for color fill, palettes, blending, and more.
base definitions used by led controllers for writing out led data
Compatibility functions based on C++ version.
Defines the DMX512-based LED controllers.
Contains definitions that can be used to configure FastLED at compile time.
Utility functions and classes for managing delay cycles.
#define NS(_NS)
Convert from nanoseconds to number of clock cycles.
Wrapper definitions to allow seamless use of PROGMEM in environments that have it.
Class base definitions for defining fast pin access.
Serial peripheral interface (SPI) definitions per platform.
Data types and constants used by SPI interfaces.
uint8_t calculate_max_brightness_for_power_mW(const CRGB *ledbuffer, uint16_t numLeds, uint8_t target_brightness, uint32_t max_power_mW)
Determines the highest brightness level you can use and still stay under the specified power budget f...
Functions to convert from the HSV colorspace to the RGB colorspace.
Determines which platform system definitions to include.
Fast, efficient 8-bit math functions specifically designed for high-performance LED programming.
Functions to generate and fill arrays with noise.
Declares classes for managing logical groups of LEDs.
Functions to limit the power used by FastLED.
Representation of an RGB pixel (Red, Green, Blue)