2021年度のキャンパスプロジェクトで使用する予定のプログラムです。
Dependencies: TLC59116
Fork of led-panel by
main.cpp
- Committer:
- Suzutomo
- Date:
- 2021-11-09
- Revision:
- 2:417ed8ce01b5
- Parent:
- 1:c3f2c02fa679
- Child:
- 5:f7b4ba4aa6af
File content as of revision 2:417ed8ce01b5:
#include "mbed.h" #include "TLC59116.h" #define PI 3.1415926535897934238 RawSerial pc(USBTX,USBRX,115200); RawSerial dev(PA_9,PA_10,115200); DigitalIn user(PC_13); I2C i2c(PB_9,PB_8); I2C arI2c(PB_4,PA_8); TLC59116 ledUnit[] = {TLC59116(&i2c,0x60 << 1), TLC59116(&i2c,0x61 << 1), TLC59116(&i2c,0x62 << 1), TLC59116(&i2c,0x63 << 1) }; char data = 0; void re() { while (1) { arI2c.read(0x10<<1,&data,1); //printf("%x\r\n",data); wait_us(0.05 * 1e3); } } void Init(); void I2cDeviceChecker(); void LightPanel(int i,uint32_t color); void LightPanel(int i,uint8_t color_r,uint8_t color_g,uint8_t color_b); void Gradation(int i,uint32_t start,uint32_t end,float per); void Send(); uint32_t HSVtoRGB(float h,float s,float v); int main() { printf("Start Program\r\n"); Thread i2cRead; i2cRead.start(re); float count = 0; int color = 0; Init(); while(1) { count += 0.01; for (int i = 0; i < 16; i++) { LightPanel(i,HSVtoRGB(fmod((i / 16.0) + count,1),1,1)); } //printf("%f",fmod((0 / 16.0) + count,1)); //float tri =abs(fmod(count / 30.0, 2.0) - 1); for (int i = 0; i < 4; i++) { if ((data >> i) & 0x01) for(int j = 0; j < 4; j++) LightPanel(i + 4*j,0xFFFFFF); //printf("%d ",(data >> i)&0x01); } //printf("%f\r\n",sin(count)); //printf("%f\r\n",tri); Send(); wait_us(1*1e6 / 60); //printf("\r\n"); } } void Init() { for (int i = 0; i <= 16; i++) { LightPanel(i - 1,0x0); LightPanel(i,0xFFFFFF); Send(); wait_us(100 * 1e3); } } void Gradation(int i,uint32_t start,uint32_t end,float per) { uint8_t s_r = (start & 0xFF0000) >> 16; uint8_t s_g = (start & 0xFF00) >> 8; uint8_t s_b = (start & 0xFF); uint8_t e_r = (end & 0xFF0000) >> 16; uint8_t e_g = (end & 0xFF00) >> 8; uint8_t e_b = (end & 0xFF); uint8_t c_r = (e_r - s_r) * per + s_r; uint8_t c_g = (e_g - s_g) * per + s_g; uint8_t c_b = (e_b - s_b) * per + s_b; ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3,c_g); ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3 + 1,c_r); ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3 + 2,c_b); } void LightPanel(int i,uint32_t color) { if (i >= 0 && i < 16) { uint8_t c_r = (color & 0xFF0000) >> 16; uint8_t c_g = (color & 0xFF00) >> 8; uint8_t c_b = (color & 0xFF); ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3,c_g); ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3 + 1,c_r); ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3 + 2,c_b); } } void LightPanel(int i,uint8_t c_r,uint8_t c_g,uint8_t c_b) { ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3,c_g); ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3 + 1,c_r); ledUnit[(int)(i / 4)].SetChannel((i % 4) * 3 + 2,c_b); } void Send() { for (int i = 0; i < 4; i++) ledUnit[i].Send(2,12); } void I2cDeviceChecker() { char data[1] = {0x00}; for (int i = 0; i < 127; i++) { printf("%2x : %d\r\n",i,i2c.write(i<<1,data,1)); } } uint32_t HSVtoRGB(float h,float s,float v) { float r = v; float g = v; float b = v; if (s > 0.0f) { h *= 6.0f; int i = (int) h; float f = h - (float) i; switch (i) { default: case 0: g *= 1 - s * (1 - f); b *= 1 - s; break; case 1: r *= 1 - s * f; b *= 1 - s; break; case 2: r *= 1 - s; b *= 1 - s * (1 - f); break; case 3: r *= 1 - s; g *= 1 - s * f; break; case 4: r *= 1 - s * (1 - f); g *= 1 - s; break; case 5: g *= 1 - s; b *= 1 - s * f; break; } } r *= 255; g *= 255; b *= 255; return ((int)r << 16) | ((int)g << 8) | (int)b; } /* SPI spi(PB_15,PB_14,PB_13); DigitalOut cs(PC_0); DigitalIn sv2[8] = { PC_4, PA_10, PB_13, PB_5, PB_14, PB_4, PB_15, PB_10, }; DigitalOut clk(PC_9); DigitalOut oe(PC_5,0); //PwmOut intb(PA_12); PwmOut sdb(PA_11); Thread te; volatile bool touch[8] = {0}; const int generallyWait = 200; void GetData(char com,char *data,int length) { cs = 0; char enable = spi.write(com); wait_us(generallyWait); if (enable == 0x55) { for (int i = 0; i < length; i++) { data[i] = spi.write(0x00); wait_us(generallyWait); } } else printf("error\r\n"); cs = 1; } void SetData(char com,char *data,int length) { cs = 0; char enable = spi.write(com); wait_us(generallyWait); if (enable == 0x55) { for (int i = 0; i < length; i++) { spi.write(data[i]); wait_us(generallyWait); } } else printf("error\r\n"); cs = 1; wait_us(150*1e3); } int Reset() { cs = 0; char enable = spi.write(0x04); cs = 1; wait_us(180 * 1e3); return enable == 0x55; } int EraseEeprom() { cs = 0; char enable = spi.write(0x0C); cs = 1; wait_us(60 * 1e3); return enable == 0x55; } int Calibrate() { cs = 0; char enable = spi.write(0x03); cs = 1; wait_us(180 * 1e3); return enable == 0x55; } void teTh() { int place[8] = {0,1,8,9,6,7,4,5}; char *data; data = new char[2]; while(1) { GetData(0xC1,data,2); int d = (data[0] << 8)| data[1]; for (int i = 0; i < 8; i++) { touch[i] = (d >> place[i]) & 0x1; } for (int i = 7; i >= 0; i--) { printf("%x",touch[i]); } printf("\r\n"); //wait_us(100); } delete data; } void main() { cs = 1; spi.format(8,3); spi.frequency(1500000); char* data; printf("Reset : %s\r\n",Reset() ? "OK" : "FALSE"); printf("Erase EEPROM : %s\r\n",EraseEeprom() ? "OK" : "FALSE"); data = new char[1]; data[0] = 0b11110010; SetData(0x90,data,1); data[0] = 0b0; SetData(0x97,data,1); SetData(0x98,data,1); data[0] = 0b00101000; for (int i = 0; i < 11; i++) { SetData(0xA3 + i,data,1); } printf("Calibrate : %s\r\n",Calibrate() ? "OK" : "FALSE"); data = new char[42]; GetData(0xC8,data,42); //spi.write(0xC9); //wait_us(150); //printf("%x\r\n",spi.write(0x00)); //cs = 1; //wait_us(50 * 1e3); //while (user.read()); //te.start(teTh); } */