summaryrefslogtreecommitdiff
path: root/src/app/ws2812b_uart
diff options
context:
space:
mode:
authorDaniel Friesel <derf@finalrewind.org>2019-11-01 16:31:13 +0100
committerDaniel Friesel <derf@finalrewind.org>2019-11-01 16:31:13 +0100
commit2d62ccb5bb0f8cea5d6a75e6fd74a7d3cdbd0c69 (patch)
tree4062388883dd42b35da5159f3a715802c5a82213 /src/app/ws2812b_uart
parent9eb55dc6e54d1287096ef66ab8ba0fff8e5a334d (diff)
ws2812b_uart: support setting arbitrary colors
Diffstat (limited to 'src/app/ws2812b_uart')
-rw-r--r--src/app/ws2812b_uart/main.cc34
1 files changed, 32 insertions, 2 deletions
diff --git a/src/app/ws2812b_uart/main.cc b/src/app/ws2812b_uart/main.cc
index 0becbf9..b35800a 100644
--- a/src/app/ws2812b_uart/main.cc
+++ b/src/app/ws2812b_uart/main.cc
@@ -26,17 +26,20 @@ class Blinkencat {
COLD_WHITE,
STROBE,
COLOR_STROBE,
+ COLOR_RGB,
MODE_ENUM_MAX
};
Mode mode;
+ uint8_t red, green, blue;
+
void setup(void);
void next_mode(void);
void idle(void);
void loop(void);
- Blinkencat() : mode(RGBWHEEL_SLOW) {}
+ Blinkencat() : mode(OFF) {}
};
void Blinkencat::setup(void)
@@ -174,6 +177,13 @@ void Blinkencat::loop(void)
strobe_on = 127 - strobe_on;
_delay_ms(40);
break;
+ case COLOR_RGB:
+ for (uint16_t i = 0; i < NUM_PIXELS; i++) {
+ np.setPixelColor(i, np.Color(red, green, blue));
+ }
+ np.show();
+ idle();
+ break;
}
}
@@ -181,6 +191,10 @@ Blinkencat blinkencat;
int main(void)
{
+ char buf[3];
+ unsigned char buf_pos = sizeof(buf);
+ Blinkencat::Mode target_mode = blinkencat.OFF;
+
arch.setup();
gpio.setup();
kout.setup();
@@ -189,12 +203,28 @@ int main(void)
blinkencat.setup();
while (1) {
+ kout << "loop - mode is " << blinkencat.mode << endl;
blinkencat.loop();
while (kin.hasKey()) {
char key = kin.getKey();
- if ((key >= '0') && (key < '0' + blinkencat.MODE_ENUM_MAX)) {
+
+ if (buf_pos < sizeof(buf)) {
+ buf[buf_pos] = key;
+ buf_pos++;
+ if (buf_pos == sizeof(buf)) {
+ blinkencat.red = buf[0];
+ blinkencat.green = buf[1];
+ blinkencat.blue = buf[2];
+ blinkencat.mode = target_mode;
+ }
+ }
+ else if ((key >= '0') && (key < '0' + blinkencat.MODE_ENUM_MAX)) {
blinkencat.mode = (Blinkencat::Mode)(key - '0');
}
+ else if (key == 'c') {
+ buf_pos = 0;
+ target_mode = blinkencat.COLOR_RGB;
+ }
}
}