Create HueValueSpectrum.ino
This commit is contained in:
parent
4cb60e0180
commit
a185b72d59
1 changed files with 78 additions and 0 deletions
78
examples/HueValueSpectrum/HueValueSpectrum.ino
Normal file
78
examples/HueValueSpectrum/HueValueSpectrum.ino
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
#define PANEL_RES_X 64 // Number of pixels wide of each INDIVIDUAL panel module.
|
||||||
|
#define PANEL_RES_Y 32 // Number of pixels tall of each INDIVIDUAL panel module.
|
||||||
|
#define PANEL_CHAIN 1 // Total number of panels chained one to another
|
||||||
|
|
||||||
|
#include <ESP32-HUB75-MatrixPanel-I2S-DMA.h>
|
||||||
|
|
||||||
|
MatrixPanel_I2S_DMA *dma_display = nullptr;
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
|
||||||
|
|
||||||
|
HUB75_I2S_CFG::i2s_pins _pins={
|
||||||
|
25, //R1_PIN,
|
||||||
|
26, //G1_PIN,
|
||||||
|
27, //B1_PIN,
|
||||||
|
14, //R2_PIN,
|
||||||
|
12, //G2_PIN,
|
||||||
|
13, //B2_PIN,
|
||||||
|
23, //A_PIN,
|
||||||
|
19, //B_PIN,
|
||||||
|
5, //C_PIN,
|
||||||
|
17, //D_PIN,
|
||||||
|
18, //E_PIN,
|
||||||
|
4, //LAT_PIN,
|
||||||
|
15, //OE_PIN,
|
||||||
|
16, //CLK_PIN
|
||||||
|
};
|
||||||
|
HUB75_I2S_CFG mxconfig(
|
||||||
|
PANEL_RES_X, // Module width
|
||||||
|
PANEL_RES_Y, // Module height
|
||||||
|
PANEL_CHAIN //, // chain length
|
||||||
|
//_pins // pin mapping -- uncomment if providing own custom pin mapping as per above.
|
||||||
|
);
|
||||||
|
//mxconfig.clkphase = false;
|
||||||
|
//mxconfig.driver = HUB75_I2S_CFG::FM6126A;
|
||||||
|
|
||||||
|
// Display Setup
|
||||||
|
dma_display = new MatrixPanel_I2S_DMA(mxconfig);
|
||||||
|
dma_display->begin();
|
||||||
|
dma_display->clearScreen();
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// Canvas loop
|
||||||
|
float t = (float) ((millis()%4000)/4000.f);
|
||||||
|
float tt = (float) ((millis()%16000)/16000.f);
|
||||||
|
|
||||||
|
for(int x = 0; x < (PANEL_RES_X*PANEL_CHAIN); x++)
|
||||||
|
{
|
||||||
|
// calculate the overal shade
|
||||||
|
float f = (((sin(tt-(float)x/PANEL_RES_Y/32.)*2.f*PI)+1)/2)*255;
|
||||||
|
// calculate hue spectrum into rgb
|
||||||
|
float r = max(min(cosf(2.f*PI*(t+((float)x/PANEL_RES_Y+0.f)/3.f))+0.5f,1.f),0.f);
|
||||||
|
float g = max(min(cosf(2.f*PI*(t+((float)x/PANEL_RES_Y+1.f)/3.f))+0.5f,1.f),0.f);
|
||||||
|
float b = max(min(cosf(2.f*PI*(t+((float)x/PANEL_RES_Y+2.f)/3.f))+0.5f,1.f),0.f);
|
||||||
|
|
||||||
|
// iterate pixels for every row
|
||||||
|
for(int y = 0; y < PANEL_RES_Y; y++){
|
||||||
|
if(y*2 < PANEL_RES_Y){
|
||||||
|
// top-middle part of screen, transition of value
|
||||||
|
float t = (2.f*y+1)/PANEL_RES_Y;
|
||||||
|
dma_display->drawPixelRGB888(x,y,
|
||||||
|
(r*t)*f,
|
||||||
|
(g*t)*f,
|
||||||
|
(b*t)*f
|
||||||
|
);
|
||||||
|
}else{
|
||||||
|
// middle to bottom of screen, transition of saturation
|
||||||
|
float t = (2.f*(PANEL_RES_Y-y)-1)/PANEL_RES_Y;
|
||||||
|
dma_display->drawPixelRGB888(x,y,
|
||||||
|
(r*t+1-t)*f,
|
||||||
|
(g*t+1-t)*f,
|
||||||
|
(b*t+1-t)*f
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue