Added effect night_clock

This commit is contained in:
Fabian Schlenz 2019-09-25 18:11:52 +02:00
parent 36edb94ff0
commit 7ac681002e
4 changed files with 44 additions and 18 deletions

View File

@ -6,12 +6,19 @@
#include "Window.h" #include "Window.h"
class ClockEffect : public Effect { class ClockEffect : public Effect {
private: protected:
Window* window = new Window(0, LED_HEIGHT - 6, LED_WIDTH, 6); Window* window = new Window(0, LED_HEIGHT - 6, LED_WIDTH, 6);
public: public:
~ClockEffect(); ~ClockEffect();
void loop(); virtual void loop();
void loop(boolean invert, CRGB fg_color, CRGB bg_color);
String get_name() override { return "clock"; } String get_name() override { return "clock"; }
void loop_with_invert(bool invert);
void loop(boolean invert, CRGB fg_color, CRGB bg_color, uint8_t y);
};
class NightClockEffect : public ClockEffect {
public:
NightClockEffect();
void loop() override;
}; };

View File

@ -4,23 +4,41 @@
#include "fonts.h" #include "fonts.h"
#include "ntp.h" #include "ntp.h"
void ClockEffect::loop() { NightClockEffect::NightClockEffect() {
loop(false, CRGB(0xFFFFFF), CRGB(0x000000)); window = Window::getFullWindow();
} }
void ClockEffect::loop(boolean invert, CRGB fg_color, CRGB bg_color) { void NightClockEffect::loop() {
uint16_t minutes = minutes16();
//uint8_t y = minutes % ((window->height - 5) * 2 - 2);
//if (y > window->height - 5) y = 2*window->height - 2*y;
uint8_t y = minutes % 10;
ClockEffect::loop(false, CRGB(0x880000), CRGB(0x000000), y);
}
void ClockEffect::loop() {
loop_with_invert(false);
}
void ClockEffect::loop_with_invert(bool invert) {
// Clear the first line to have a bit of space to the other stuff on screen
CRGB bg_color(0x000000);
for(int i=0; i<window->width; i++) window->setPixel(i, 0, &bg_color);
loop(invert, CRGB(0xFFFFFF), bg_color, 1);
}
void ClockEffect::loop(boolean invert, CRGB fg_color, CRGB bg_color, uint8_t yPos) {
if (!invert) { if (!invert) {
window->clear(&bg_color); window->clear(&bg_color);
} else { } else {
// Manually clear the needed parts // Manually clear the needed parts
for(int i=0; i<window->width; i++) window->setPixel(i, 0, &bg_color);
for(int y=0; y<6; y++) { for(int y=0; y<6; y++) {
window->setPixel(3, y, &bg_color); window->setPixel(3, yPos+y, &bg_color);
if (y!=2 && y!=4) { if (y!=2 && y!=4) {
window->setPixel(7, y, &bg_color); window->setPixel(7, yPos+y, &bg_color);
} }
window->setPixel(8, y, &bg_color); window->setPixel(8, yPos+y, &bg_color);
window->setPixel(12, y, &bg_color); window->setPixel(12, yPos+y, &bg_color);
} }
fg_color = bg_color; fg_color = bg_color;
} }
@ -30,14 +48,14 @@ void ClockEffect::loop(boolean invert, CRGB fg_color, CRGB bg_color) {
} }
int h = ntpClient.getHours(); int h = ntpClient.getHours();
//void drawChar(Font f, uint8_t x, uint8_t y, const char c, CRGB* color, bool mask=false); //void drawChar(Font f, uint8_t x, uint8_t y, const char c, CRGB* color, bool mask=false);
window->drawChar(&font_numbers3x5, 0<<8, 1<<8, '0' + (h / 10), &fg_color, invert); window->drawChar(&font_numbers3x5, 0<<8, yPos<<8, '0' + (h / 10), &fg_color, invert);
window->drawChar(&font_numbers3x5, 4<<8, 1<<8, '0' + (h % 10), &fg_color, invert); window->drawChar(&font_numbers3x5, 4<<8, yPos<<8, '0' + (h % 10), &fg_color, invert);
int m = ntpClient.getMinutes(); int m = ntpClient.getMinutes();
window->drawChar(&font_numbers3x5, 9<<8, 1<<8, '0' + (m / 10), &fg_color, invert); window->drawChar(&font_numbers3x5, 9<<8, yPos<<8, '0' + (m / 10), &fg_color, invert);
window->drawChar(&font_numbers3x5, 13<<8, 1<<8, '0' + (m % 10), &fg_color, invert); window->drawChar(&font_numbers3x5, 13<<8, yPos<<8, '0' + (m % 10), &fg_color, invert);
if (ntpClient.getSeconds() & 1) { if (ntpClient.getSeconds() & 1) {
window->setPixel(7, 2, &fg_color); window->setPixel(7, yPos+1, &fg_color);
window->setPixel(7, 4, &fg_color); window->setPixel(7, yPos+3, &fg_color);
} }
} }

View File

@ -59,6 +59,7 @@ Effect* select_effect(uint32_t code) {
case 26: case 0xADB18CC5 /* sines */ : return new SinesEffect(); case 26: case 0xADB18CC5 /* sines */ : return new SinesEffect();
case 27: case 0x0407881E /* blur2d */ : return new Blur2DEffect(); case 27: case 0x0407881E /* blur2d */ : return new Blur2DEffect();
case 28: case 0x935CFA7C /* marquee */ : return new MarqueeEffect(); case 28: case 0x935CFA7C /* marquee */ : return new MarqueeEffect();
case 29: case 0xE27D739E /* night_clock */ : return new NightClockEffect();
default : return NULL; default : return NULL;
}; };
} }

View File

@ -92,7 +92,7 @@ void loop() {
//LOGln("Core * loop ran"); //LOGln("Core * loop ran");
if (current_effect->can_be_shown_with_clock()) { if (current_effect->can_be_shown_with_clock()) {
effect_clock.loop(current_effect->clock_as_mask(), CRGB(0xFFFFFF), CRGB(0x000000)); effect_clock.loop_with_invert(current_effect->clock_as_mask());
} }
FastLED.show(); FastLED.show();
#ifdef MQTT_REPORT_METRICS #ifdef MQTT_REPORT_METRICS