FastLED 3.9.12
Loading...
Searching...
No Matches
CRGBPalette256 Class Reference

Detailed Description

RGB color palette with 256 discrete values.

Definition at line 1745 of file colorutils.h.

#include <colorutils.h>

Public Member Functions

 CRGBPalette256 ()
 Default constructor.
 
 CRGBPalette256 (const CRGB &c00, const CRGB &c01, const CRGB &c02, const CRGB &c03, const CRGB &c04, const CRGB &c05, const CRGB &c06, const CRGB &c07, const CRGB &c08, const CRGB &c09, const CRGB &c10, const CRGB &c11, const CRGB &c12, const CRGB &c13, const CRGB &c14, const CRGB &c15)
 Create palette from 16 CRGB values.
 
 CRGBPalette256 (const CRGBPalette256 &rhs)
 Copy constructor.
 
 CRGBPalette256 (const CRGB rhs[256])
 Create palette from array of CRGB colors.
 
CRGBPalette256operator= (const CRGBPalette256 &rhs)
 Copy constructor.
 
CRGBPalette256operator= (const CRGB rhs[256])
 Create palette from array of CRGB colors.
 
 CRGBPalette256 (const CHSVPalette256 &rhs)
 Create palette from CHSV palette.
 
 CRGBPalette256 (const CHSV rhs[256])
 Create palette from array of CHSV colors.
 
CRGBPalette256operator= (const CHSVPalette256 &rhs)
 Copy constructor.
 
CRGBPalette256operator= (const CHSV rhs[256])
 Create palette from array of CHSV colors.
 
 CRGBPalette256 (const CRGBPalette16 &rhs16)
 Create upscaled palette from 16-entry palette.
 
CRGBPalette256operator= (const CRGBPalette16 &rhs16)
 Create upscaled palette from 16-entry palette.
 
 CRGBPalette256 (const TProgmemRGBPalette16 &rhs)
 Create palette from palette stored in PROGMEM.
 
CRGBPalette256operator= (const TProgmemRGBPalette16 &rhs)
 Create palette from palette stored in PROGMEM.
 
bool operator== (const CRGBPalette256 &rhs) const
 Check if two palettes have the same color entries.
 
bool operator!= (const CRGBPalette256 &rhs) const
 Check if two palettes do not have the same color entries.
 
CRGBoperator[] (uint8_t x)
 Array access operator to index into the gradient entries.
 
const CRGBoperator[] (uint8_t x) const
 Array access operator to index into the gradient entries.
 
CRGBoperator[] (int x)
 Array access operator to index into the gradient entries.
 
const CRGBoperator[] (int x) const
 Array access operator to index into the gradient entries.
 
 operator CRGB * ()
 Get the underlying pointer to the CHSV entries making up the palette.
 
 CRGBPalette256 (const CHSV &c1)
 Create palette filled with one color.
 
 CRGBPalette256 (const CHSV &c1, const CHSV &c2)
 Create palette with a gradient from one color to another.
 
 CRGBPalette256 (const CHSV &c1, const CHSV &c2, const CHSV &c3)
 Create palette with three-color gradient.
 
 CRGBPalette256 (const CHSV &c1, const CHSV &c2, const CHSV &c3, const CHSV &c4)
 Create palette with four-color gradient.
 
 CRGBPalette256 (const CRGB &c1)
 Create palette filled with one color.
 
 CRGBPalette256 (const CRGB &c1, const CRGB &c2)
 Create palette with a gradient from one color to another.
 
 CRGBPalette256 (const CRGB &c1, const CRGB &c2, const CRGB &c3)
 Create palette with three-color gradient.
 
 CRGBPalette256 (const CRGB &c1, const CRGB &c2, const CRGB &c3, const CRGB &c4)
 Create palette with four-color gradient.
 
 CRGBPalette256 (TProgmemRGBGradientPalette_bytes progpal)
 Creates a palette from a gradient palette in PROGMEM.
 
CRGBPalette256operator= (TProgmemRGBGradientPalette_bytes progpal)
 Creates a palette from a gradient palette in PROGMEM.
 
CRGBPalette256loadDynamicGradientPalette (TDynamicRGBGradientPalette_bytes gpal)
 Creates a palette from a gradient palette in dynamic (heap) memory.
 

Public Attributes

CRGB entries [256]
 the color entries that make up the palette
 

Constructor & Destructor Documentation

◆ CRGBPalette256() [1/17]

CRGBPalette256::CRGBPalette256 ( )
inline

Default constructor.

Warning
Default values are UNITIALIZED!

Definition at line 1750 of file colorutils.h.

◆ CRGBPalette256() [2/17]

CRGBPalette256::CRGBPalette256 ( const CRGB & c00,
const CRGB & c01,
const CRGB & c02,
const CRGB & c03,
const CRGB & c04,
const CRGB & c05,
const CRGB & c06,
const CRGB & c07,
const CRGB & c08,
const CRGB & c09,
const CRGB & c10,
const CRGB & c11,
const CRGB & c12,
const CRGB & c13,
const CRGB & c14,
const CRGB & c15 )
inline

Create palette from 16 CRGB values.

Definition at line 1757 of file colorutils.h.

◆ CRGBPalette256() [3/17]

CRGBPalette256::CRGBPalette256 ( const CRGBPalette256 & rhs)
inline

Copy constructor.

Definition at line 1768 of file colorutils.h.

◆ CRGBPalette256() [4/17]

CRGBPalette256::CRGBPalette256 ( const CRGB rhs[256])
inline

Create palette from array of CRGB colors.

Definition at line 1773 of file colorutils.h.

◆ CRGBPalette256() [5/17]

CRGBPalette256::CRGBPalette256 ( const CHSVPalette256 & rhs)
inline

Create palette from CHSV palette.

Definition at line 1791 of file colorutils.h.

◆ CRGBPalette256() [6/17]

CRGBPalette256::CRGBPalette256 ( const CHSV rhs[256])
inline

Create palette from array of CHSV colors.

Definition at line 1798 of file colorutils.h.

◆ CRGBPalette256() [7/17]

CRGBPalette256::CRGBPalette256 ( const CRGBPalette16 & rhs16)
inline

Create upscaled palette from 16-entry palette.

Definition at line 1822 of file colorutils.h.

◆ CRGBPalette256() [8/17]

CRGBPalette256::CRGBPalette256 ( const TProgmemRGBPalette16 & rhs)
inline

Create palette from palette stored in PROGMEM.

Definition at line 1834 of file colorutils.h.

◆ CRGBPalette256() [9/17]

CRGBPalette256::CRGBPalette256 ( const CHSV & c1)
inline

Create palette filled with one color.

Parameters
c1the color to fill the palette with

Definition at line 1895 of file colorutils.h.

◆ CRGBPalette256() [10/17]

CRGBPalette256::CRGBPalette256 ( const CHSV & c1,
const CHSV & c2 )
inline

Create palette with a gradient from one color to another.

Parameters
c1the starting color for the gradient
c2the end color for the gradient

Definition at line 1900 of file colorutils.h.

◆ CRGBPalette256() [11/17]

CRGBPalette256::CRGBPalette256 ( const CHSV & c1,
const CHSV & c2,
const CHSV & c3 )
inline

Create palette with three-color gradient.

Parameters
c1the starting color for the gradient
c2the middle color for the gradient
c3the end color for the gradient

Definition at line 1905 of file colorutils.h.

◆ CRGBPalette256() [12/17]

CRGBPalette256::CRGBPalette256 ( const CHSV & c1,
const CHSV & c2,
const CHSV & c3,
const CHSV & c4 )
inline

Create palette with four-color gradient.

Parameters
c1the starting color for the gradient
c2the first middle color for the gradient
c3the second middle color for the gradient
c4the end color for the gradient

Definition at line 1910 of file colorutils.h.

◆ CRGBPalette256() [13/17]

CRGBPalette256::CRGBPalette256 ( const CRGB & c1)
inline

Create palette filled with one color.

Parameters
c1the color to fill the palette with

Definition at line 1916 of file colorutils.h.

◆ CRGBPalette256() [14/17]

CRGBPalette256::CRGBPalette256 ( const CRGB & c1,
const CRGB & c2 )
inline

Create palette with a gradient from one color to another.

Parameters
c1the starting color for the gradient
c2the end color for the gradient

Definition at line 1921 of file colorutils.h.

◆ CRGBPalette256() [15/17]

CRGBPalette256::CRGBPalette256 ( const CRGB & c1,
const CRGB & c2,
const CRGB & c3 )
inline

Create palette with three-color gradient.

Parameters
c1the starting color for the gradient
c2the middle color for the gradient
c3the end color for the gradient

Definition at line 1926 of file colorutils.h.

◆ CRGBPalette256() [16/17]

CRGBPalette256::CRGBPalette256 ( const CRGB & c1,
const CRGB & c2,
const CRGB & c3,
const CRGB & c4 )
inline

Create palette with four-color gradient.

Parameters
c1the starting color for the gradient
c2the first middle color for the gradient
c3the second middle color for the gradient
c4the end color for the gradient

Definition at line 1931 of file colorutils.h.

◆ CRGBPalette256() [17/17]

CRGBPalette256::CRGBPalette256 ( TProgmemRGBGradientPalette_bytes progpal)
inline

Creates a palette from a gradient palette in PROGMEM.

Gradient palettes are loaded into CRGBPalettes in such a way that, if possible, every color represented in the gradient palette is also represented in the CRGBPalette.

For example, consider a gradient palette that is all black except for a single, one-element-wide (1/256th!) spike of red in the middle:

0, 0,0,0
124, 0,0,0
125, 255,0,0 // one 1/256th-palette-wide red stripe
126, 0,0,0
255, 0,0,0

A naive conversion of this 256-element palette to a 16-element palette might accidentally completely eliminate the red spike, rendering the palette completely black.

However, the conversions provided here would attempt to include a the red stripe in the output, more-or-less as faithfully as possible. So in this case, the resulting CRGBPalette16 palette would have a red stripe in the middle which was 1/16th of a palette wide – the narrowest possible in a CRGBPalette16.

This means that the relative width of stripes in a CRGBPalette16 will be, by definition, different from the widths in the gradient palette. This code attempts to preserve "all the colors", rather than the exact stripe widths at the expense of dropping some colors.

Definition at line 1937 of file colorutils.h.

Member Function Documentation

◆ loadDynamicGradientPalette()

CRGBPalette256 & CRGBPalette256::loadDynamicGradientPalette ( TDynamicRGBGradientPalette_bytes gpal)
inline

Creates a palette from a gradient palette in dynamic (heap) memory.

Gradient palettes are loaded into CRGBPalettes in such a way that, if possible, every color represented in the gradient palette is also represented in the CRGBPalette.

For example, consider a gradient palette that is all black except for a single, one-element-wide (1/256th!) spike of red in the middle:

0, 0,0,0
124, 0,0,0
125, 255,0,0 // one 1/256th-palette-wide red stripe
126, 0,0,0
255, 0,0,0

A naive conversion of this 256-element palette to a 16-element palette might accidentally completely eliminate the red spike, rendering the palette completely black.

However, the conversions provided here would attempt to include a the red stripe in the output, more-or-less as faithfully as possible. So in this case, the resulting CRGBPalette16 palette would have a red stripe in the middle which was 1/16th of a palette wide – the narrowest possible in a CRGBPalette16.

This means that the relative width of stripes in a CRGBPalette16 will be, by definition, different from the widths in the gradient palette. This code attempts to preserve "all the colors", rather than the exact stripe widths at the expense of dropping some colors.

Definition at line 1962 of file colorutils.h.

◆ operator CRGB *()

CRGBPalette256::operator CRGB * ( )
inline

Get the underlying pointer to the CHSV entries making up the palette.

Definition at line 1889 of file colorutils.h.

◆ operator!=()

bool CRGBPalette256::operator!= ( const CRGBPalette256 & rhs) const
inline

Check if two palettes do not have the same color entries.

Definition at line 1861 of file colorutils.h.

◆ operator=() [1/7]

CRGBPalette256 & CRGBPalette256::operator= ( const CHSV rhs[256])
inline

Create palette from array of CHSV colors.

Definition at line 1813 of file colorutils.h.

◆ operator=() [2/7]

CRGBPalette256 & CRGBPalette256::operator= ( const CHSVPalette256 & rhs)
inline

Copy constructor.

Definition at line 1805 of file colorutils.h.

◆ operator=() [3/7]

CRGBPalette256 & CRGBPalette256::operator= ( const CRGB rhs[256])
inline

Create palette from array of CRGB colors.

Definition at line 1784 of file colorutils.h.

◆ operator=() [4/7]

CRGBPalette256 & CRGBPalette256::operator= ( const CRGBPalette16 & rhs16)
inline

Create upscaled palette from 16-entry palette.

Definition at line 1827 of file colorutils.h.

◆ operator=() [5/7]

CRGBPalette256 & CRGBPalette256::operator= ( const CRGBPalette256 & rhs)
inline

Copy constructor.

Definition at line 1778 of file colorutils.h.

◆ operator=() [6/7]

CRGBPalette256 & CRGBPalette256::operator= ( const TProgmemRGBPalette16 & rhs)
inline

Create palette from palette stored in PROGMEM.

Definition at line 1840 of file colorutils.h.

◆ operator=() [7/7]

CRGBPalette256 & CRGBPalette256::operator= ( TProgmemRGBGradientPalette_bytes progpal)
inline

Creates a palette from a gradient palette in PROGMEM.

Gradient palettes are loaded into CRGBPalettes in such a way that, if possible, every color represented in the gradient palette is also represented in the CRGBPalette.

For example, consider a gradient palette that is all black except for a single, one-element-wide (1/256th!) spike of red in the middle:

0, 0,0,0
124, 0,0,0
125, 255,0,0 // one 1/256th-palette-wide red stripe
126, 0,0,0
255, 0,0,0

A naive conversion of this 256-element palette to a 16-element palette might accidentally completely eliminate the red spike, rendering the palette completely black.

However, the conversions provided here would attempt to include a the red stripe in the output, more-or-less as faithfully as possible. So in this case, the resulting CRGBPalette16 palette would have a red stripe in the middle which was 1/16th of a palette wide – the narrowest possible in a CRGBPalette16.

This means that the relative width of stripes in a CRGBPalette16 will be, by definition, different from the widths in the gradient palette. This code attempts to preserve "all the colors", rather than the exact stripe widths at the expense of dropping some colors.

Definition at line 1942 of file colorutils.h.

◆ operator==()

bool CRGBPalette256::operator== ( const CRGBPalette256 & rhs) const
inline

Check if two palettes have the same color entries.

Definition at line 1848 of file colorutils.h.

◆ operator[]() [1/4]

CRGB & CRGBPalette256::operator[] ( int x)
inline

Array access operator to index into the gradient entries.

Parameters
xthe index to retrieve
Returns
reference to an entry in the palette's color array
Note
This does not perform any interpolation like ColorFromPalette(), it accesses the underlying entries that make up the gradient. Beware of bounds issues!

Definition at line 1878 of file colorutils.h.

◆ operator[]() [2/4]

const CRGB & CRGBPalette256::operator[] ( int x) const
inline

Array access operator to index into the gradient entries.

Parameters
xthe index to retrieve
Returns
reference to an entry in the palette's color array
Note
This does not perform any interpolation like ColorFromPalette(), it accesses the underlying entries that make up the gradient. Beware of bounds issues!

Definition at line 1883 of file colorutils.h.

◆ operator[]() [3/4]

CRGB & CRGBPalette256::operator[] ( uint8_t x)
inline

Array access operator to index into the gradient entries.

Parameters
xthe index to retrieve
Returns
reference to an entry in the palette's color array
Note
This does not perform any interpolation like ColorFromPalette(), it accesses the underlying entries that make up the gradient. Beware of bounds issues!

Definition at line 1867 of file colorutils.h.

◆ operator[]() [4/4]

const CRGB & CRGBPalette256::operator[] ( uint8_t x) const
inline

Array access operator to index into the gradient entries.

Parameters
xthe index to retrieve
Returns
reference to an entry in the palette's color array
Note
This does not perform any interpolation like ColorFromPalette(), it accesses the underlying entries that make up the gradient. Beware of bounds issues!

Definition at line 1872 of file colorutils.h.

Member Data Documentation

◆ entries

CRGB CRGBPalette256::entries[256]

the color entries that make up the palette

Definition at line 1747 of file colorutils.h.


The documentation for this class was generated from the following file: