summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/app/blinkencat3/main.cc41
1 files changed, 30 insertions, 11 deletions
diff --git a/src/app/blinkencat3/main.cc b/src/app/blinkencat3/main.cc
index 79753b6..263822e 100644
--- a/src/app/blinkencat3/main.cc
+++ b/src/app/blinkencat3/main.cc
@@ -21,8 +21,11 @@ class Blinkencat {
RGBWHEEL_SLOW,
RGBFADE_FAST,
RGBFADE_SLOW,
+ BRIGHTRGBWHEEL_FAST,
+ BRIGHTRGBWHEEL_SLOW,
+ BRIGHTRGBFADE_FAST,
+ BRIGHTRGBFADE_SLOW,
COLD_WHITE,
- BEEDOO,
STROBE,
COLOR_STROBE,
MODE_ENUM_MAX
@@ -139,7 +142,6 @@ void Blinkencat::loop(void)
{
static uint16_t rgbwheel_offset = 0;
static uint16_t rgbfade_hsv = 0;
- static uint8_t beedoo_pos = 0;
static uint8_t strobe_on = 0;
/*
@@ -168,7 +170,7 @@ void Blinkencat::loop(void)
case RGBWHEEL_SLOW:
for (uint16_t i = 0; i < NUM_PIXELS; i++) {
uint16_t hsv = (i * 252 + rgbwheel_offset) % 6553;
- np.setPixelColor(i, np.gamma32(np.ColorHSV(hsv * 10)));
+ np.setPixelColor(i, np.gamma32(np.ColorHSV(hsv * 10, 255, 127)));
}
rgbwheel_offset = (rgbwheel_offset + 10) % 6553;
np.show();
@@ -180,7 +182,7 @@ void Blinkencat::loop(void)
case RGBFADE_FAST:
case RGBFADE_SLOW:
for (uint16_t i = 0; i < NUM_PIXELS; i++) {
- np.setPixelColor(i, np.ColorHSV(rgbfade_hsv * 10));
+ np.setPixelColor(i, np.ColorHSV(rgbfade_hsv * 10, 255, 63));
}
rgbfade_hsv = (rgbfade_hsv + 10) % 6553;
np.show();
@@ -189,20 +191,37 @@ void Blinkencat::loop(void)
_delay_ms(99);
}
break;
- case COLD_WHITE:
+ case BRIGHTRGBWHEEL_FAST:
+ case BRIGHTRGBWHEEL_SLOW:
for (uint16_t i = 0; i < NUM_PIXELS; i++) {
- np.setPixelColor(i, np.Color(127, 127, 127));
+ uint16_t hsv = (i * 252 + rgbwheel_offset) % 6553;
+ np.setPixelColor(i, np.gamma32(np.ColorHSV(hsv * 10)));
}
+ rgbwheel_offset = (rgbwheel_offset + 10) % 6553;
np.show();
- sleep();
+ _delay_ms(1);
+ if (mode == BRIGHTRGBWHEEL_SLOW) {
+ _delay_ms(9);
+ }
break;
- case BEEDOO:
+ case BRIGHTRGBFADE_FAST:
+ case BRIGHTRGBFADE_SLOW:
for (uint16_t i = 0; i < NUM_PIXELS; i++) {
- np.setPixelColor(i, np.Color(0, 0, (i+2 - beedoo_pos <= 2) * 255));
+ np.setPixelColor(i, np.ColorHSV(rgbfade_hsv * 10));
}
+ rgbfade_hsv = (rgbfade_hsv + 10) % 6553;
np.show();
- beedoo_pos = (beedoo_pos + 1) % NUM_PIXELS;
- _delay_ms(20);
+ _delay_ms(1);
+ if (mode == BRIGHTRGBFADE_SLOW) {
+ _delay_ms(99);
+ }
+ break;
+ case COLD_WHITE:
+ for (uint16_t i = 0; i < NUM_PIXELS; i++) {
+ np.setPixelColor(i, np.Color(127, 127, 127));
+ }
+ np.show();
+ sleep();
break;
case STROBE:
for (uint16_t i = 0; i < NUM_PIXELS; i++) {