This commit is contained in:
2019-05-04 12:51:55 +02:00
committed by 0xFEEDC0DE64
parent 9e1d88db16
commit 531a10fa19
5 changed files with 96 additions and 9 deletions

View File

@@ -16,11 +16,51 @@
FASTLED_USING_NAMESPACE FASTLED_USING_NAMESPACE
class RGBTest : public Pattern
{
public:
using Pattern::Pattern;
const char * name() const override
{
return "rgbtest";
}
void run() override
{
CRGB color;
switch(m_index)
{
case 0:
case 1:
color = CRGB::Red;
break;
case 2:
color = CRGB::Green;
break;
case 3:
color = CRGB::Blue;
}
fill_solid(&leds[0], NUM_LEDS, color);
EVERY_N_SECONDS(1)
{
m_index++;
if (m_index >= 4)
m_index = 0;
}
}
private:
int m_index = 0;
};
class LedController class LedController
{ {
public: public:
LedController() : LedController() :
controller(FastLED.addLeds<WS2812, pin, RGB>(&leds[0], leds.size())), controller(FastLED.addLeds<WS2812, pin, BRG>(&leds[0], leds.size())),
m_rainbow(leds), m_rainbow(leds),
m_rainbowWithGlitter(leds), m_rainbowWithGlitter(leds),
m_confetti(leds), m_confetti(leds),
@@ -28,7 +68,8 @@ public:
m_juggle(leds), m_juggle(leds),
m_bpm(leds), m_bpm(leds),
m_fire2012(leds), m_fire2012(leds),
patterns { &m_rainbow, &m_rainbowWithGlitter, &m_confetti, &m_sineleon, &m_juggle, &m_bpm, &m_fire2012 }, m_rgbtest(leds),
patterns { &m_rainbow, &m_rainbowWithGlitter, &m_confetti, &m_sineleon, &m_juggle, &m_bpm, &m_fire2012, &m_rgbtest },
iter(patterns.begin()) iter(patterns.begin())
{ {
controller.setCorrection(TypicalLEDStrip); controller.setCorrection(TypicalLEDStrip);
@@ -62,8 +103,10 @@ private:
JugglePattern m_juggle; JugglePattern m_juggle;
BpmPattern m_bpm; BpmPattern m_bpm;
Fire2012Pattern m_fire2012; Fire2012Pattern m_fire2012;
RGBTest m_rgbtest;
public: public:
using PatternContainer = std::array<Pattern*, 8>;
const PatternContainer patterns; const PatternContainer patterns;
PatternContainer::const_iterator iter; PatternContainer::const_iterator iter;
}; };

View File

@@ -2,6 +2,7 @@
#include <array> #include <array>
#include <Arduino.h>
#include <FastLED.h> #include <FastLED.h>
FASTLED_USING_NAMESPACE FASTLED_USING_NAMESPACE
@@ -11,4 +12,3 @@ class Pattern;
constexpr auto pin = 0; constexpr auto pin = 0;
constexpr auto NUM_LEDS = 100; constexpr auto NUM_LEDS = 100;
using LedContainer = std::array<CRGB, NUM_LEDS>; using LedContainer = std::array<CRGB, NUM_LEDS>;
using PatternContainer = std::array<Pattern*, 7>;

View File

@@ -20,6 +20,9 @@ bool rotatePattern = true;
void setup() void setup()
{ {
Serial.begin(115200);
Serial.setDebugOutput(true);
WiFi.begin(WIFI_SSID, WIFI_PASSWD); WiFi.begin(WIFI_SSID, WIFI_PASSWD);
server.on("/", HTTP_GET, []() server.on("/", HTTP_GET, []()
@@ -43,11 +46,11 @@ void setup()
"}" "}"
"</style>" "</style>"
"<title>Hello, world!</title>" "<title>LED-Control</title>"
"</head>" "</head>"
"<body>" "<body>"
"<div class=\"container\">" "<div class=\"container\">"
"<h1>Hello, world!</h1>" "<h1>LED-Control</h1>"
"<p>" "<p>"
"<a href=\"setPower?val=true\" id=\"enablePower\" class=\"softLink\">Turn LEDs on</a> " "<a href=\"setPower?val=true\" id=\"enablePower\" class=\"softLink\">Turn LEDs on</a> "
"<a href=\"setPower?val=false\" id=\"disablePower\" class=\"softLink\">Turn LEDs off</a> " "<a href=\"setPower?val=false\" id=\"disablePower\" class=\"softLink\">Turn LEDs off</a> "
@@ -132,6 +135,45 @@ void setup()
); );
}); });
server.on("/update", HTTP_GET, []() {
server.sendHeader("Connection", "close");
server.send(200, "text/html",
"<form method=\"POST\" action=\"/update\" enctype=\"multipart/form-data\">"
"<input type=\"file\" name=\"update\" />"
"<button type=\"submit\">Install</button>"
"</form>");
});
server.on("/update", HTTP_POST, []() {
server.sendHeader("Connection", "close");
server.send(200, "text/plain", (Update.hasError()) ? "FAIL" : "OK");
ESP.restart();
}, []() {
HTTPUpload& upload = server.upload();
if (upload.status == UPLOAD_FILE_START) {
Serial.setDebugOutput(true);
Serial.printf("Update: %s\n", upload.filename.c_str());
uint32_t maxSketchSpace = (ESP.getFreeSketchSpace() - 0x1000) & 0xFFFFF000;
if (!Update.begin(maxSketchSpace)) { //start with max available size
Update.printError(Serial);
}
} else if (upload.status == UPLOAD_FILE_WRITE) {
if (Update.write(upload.buf, upload.currentSize) != upload.currentSize) {
Update.printError(Serial);
}
} else if (upload.status == UPLOAD_FILE_END) {
if (Update.end(true)) { //true to set the size to the current progress
Serial.printf("Update Success: %u\nRebooting...\n", upload.totalSize);
} else {
Update.printError(Serial);
}
Serial.setDebugOutput(false);
}
yield();
});
server.on("/status", HTTP_GET, []() server.on("/status", HTTP_GET, []()
{ {
server.sendHeader("Connection", "close"); server.sendHeader("Connection", "close");

View File

@@ -4,7 +4,7 @@
class Pattern { class Pattern {
public: public:
Pattern(LedContainer leds) : Pattern(LedContainer &leds) :
leds(leds) leds(leds)
{ {
} }

View File

@@ -20,13 +20,15 @@ public:
void run() override void run() override
{ {
uint8_t BeatsPerMinute = 62;
CRGBPalette16 palette = PartyColors_p;
uint8_t beat = beatsin8(BeatsPerMinute, 64, 255); uint8_t beat = beatsin8(BeatsPerMinute, 64, 255);
for(int i = 0; i < leds.size(); i++) for(int i = 0; i < leds.size(); i++)
leds[i] = ColorFromPalette(palette, gHue+(i*2), beat-(gHue++)+(i*10)); leds[i] = ColorFromPalette(palette, gHue+(i*2), beat-gHue+(i*10));
gHue++;
} }
private: private:
static constexpr uint8_t BeatsPerMinute = 62;
const CRGBPalette16 &palette = *reinterpret_cast<const CRGBPalette16*>(&PartyColors_p);
uint8_t gHue = 0; uint8_t gHue = 0;
}; };