Added auto cycle feature

This commit is contained in:
Keith Lord 2017-09-19 18:31:03 -04:00
parent d0ccc58aff
commit bc2984cffc
4 changed files with 96 additions and 31 deletions

View file

@ -348,7 +348,10 @@ void setup() {
size_t fileSize = dir.fileSize(); size_t fileSize = dir.fileSize();
DBG_OUTPUT_PORT.printf("FS File: %s, size: %s\n", fileName.c_str(), formatBytes(fileSize).c_str()); DBG_OUTPUT_PORT.printf("FS File: %s, size: %s\n", fileName.c_str(), formatBytes(fileSize).c_str());
} }
DBG_OUTPUT_PORT.printf("\n");
FSInfo fs_info;
SPIFFS.info(fs_info);
DBG_OUTPUT_PORT.printf("FS Usage: %d/%d bytes\n\n", fs_info.usedBytes, fs_info.totalBytes);
} }
// *************************************************************************** // ***************************************************************************

View file

@ -7,6 +7,14 @@ const char HOSTNAME[] = "ESP8266_01"; // Friedly hostname
#define ENABLE_OTA // If defined, enable Arduino OTA code. #define ENABLE_OTA // If defined, enable Arduino OTA code.
#define ENABLE_MQTT // If defined, enable MQTT client code. #define ENABLE_MQTT // If defined, enable MQTT client code.
// parameters for automatically cycling favorite patterns
uint32_t autoParams[][4] = { // color, speed, mode, duration (seconds)
{0xff0000, 200, 1, 5.0}, // blink red for 5 seconds
{0x00ff00, 200, 3, 10.0}, // wipe green for 10 seconds
{0x0000ff, 200, 11, 5.0} // dual scan blue for 5 seconds
};
#ifdef ENABLE_MQTT #ifdef ENABLE_MQTT
#define MQTT_MAX_PACKET_SIZE 256 #define MQTT_MAX_PACKET_SIZE 256
#define MQTT_MAX_RECONNECT_TRIES 4 #define MQTT_MAX_RECONNECT_TRIES 4

View file

@ -123,11 +123,17 @@ void handleSetWS2812FXMode(uint8_t * mypayload) {
ws2812fx_mode = constrain(ws2812fx_mode, 0, 255); ws2812fx_mode = constrain(ws2812fx_mode, 0, 255);
strip.setColor(main_color.red, main_color.green, main_color.blue); strip.setColor(main_color.red, main_color.green, main_color.blue);
strip.setMode(ws2812fx_mode); strip.setMode(ws2812fx_mode);
strip.start();
} }
char* listStatusJSON() { char* listStatusJSON() {
char json[255]; char json[255];
snprintf(json, sizeof(json), "{\"mode\":%d, \"ws2812fx_mode\":%d, \"ws2812fx_mode_name\":\"%s\", \"speed\":%d, \"brightness\":%d, \"color\":[%d, %d, %d]}", mode, strip.getMode(), strip.getModeName(strip.getMode()), ws2812fx_speed, brightness, main_color.red, main_color.green, main_color.blue);
char modeName[30];
strncpy_P(modeName, (PGM_P)strip.getModeName(strip.getMode()), sizeof(modeName)); // copy from progmem
snprintf(json, sizeof(json), "{\"mode\":%d, \"ws2812fx_mode\":%d, \"ws2812fx_mode_name\":\"%s\", \"speed\":%d, \"brightness\":%d, \"color\":[%d, %d, %d]}",
mode, strip.getMode(), modeName, ws2812fx_speed, brightness, main_color.red, main_color.green, main_color.blue);
return json; return json;
} }
@ -158,29 +164,25 @@ void getModesJSON() {
// *************************************************************************** // ***************************************************************************
void handleMinimalUpload() { void handleMinimalUpload() {
char temp[1500]; char temp[1500];
int sec = millis() / 1000;
int min = sec / 60;
int hr = min / 60;
snprintf ( temp, 1500, snprintf ( temp, 1500,
"<!DOCTYPE html>\ "<!DOCTYPE html>\
<html>\ <html>\
<head>\ <head>\
<title>ESP8266 Upload</title>\ <title>ESP8266 Upload</title>\
<meta charset=\"utf-8\">\ <meta charset=\"utf-8\">\
<meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\ <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\
<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\ <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\
</head>\ </head>\
<body>\ <body>\
<form action=\"/edit\" method=\"post\" enctype=\"multipart/form-data\">\ <form action=\"/edit\" method=\"post\" enctype=\"multipart/form-data\">\
<input type=\"file\" name=\"data\">\ <input type=\"file\" name=\"data\">\
<input type=\"text\" name=\"path\" value=\"/\">\ <input type=\"text\" name=\"path\" value=\"/\">\
<button>Upload</button>\ <button>Upload</button>\
</form>\ </form>\
</body>\ </body>\
</html>", </html>"
hr, min % 60, sec % 60 );
);
server.send ( 200, "text/html", temp ); server.send ( 200, "text/html", temp );
} }
@ -199,6 +201,32 @@ void handleNotFound() {
server.send ( 404, "text/plain", message ); server.send ( 404, "text/plain", message );
} }
// automatic cycling
Ticker autoTicker;
int autoCount = 0;
void autoTick() {
strip.setColor(autoParams[autoCount][0]);
strip.setSpeed((uint8_t)autoParams[autoCount][1]);
strip.setMode((uint8_t)autoParams[autoCount][2]);
autoTicker.once((float)autoParams[autoCount][3], autoTick);
DBG_OUTPUT_PORT.print("autoTick ");
DBG_OUTPUT_PORT.println(autoCount);
autoCount++;
if(autoCount >= (sizeof(autoParams) / sizeof(autoParams[0]))) autoCount=0;
}
void handleAutoStart() {
autoCount=0;
autoTick();
strip.start();
}
void handleAutoStop() {
autoTicker.detach();
strip.stop();
}
// *************************************************************************** // ***************************************************************************
// WS request handlers // WS request handlers
@ -292,6 +320,18 @@ void webSocketEvent(uint8_t num, WStype_t type, uint8_t * payload, size_t lenght
handleSetWS2812FXMode(payload); handleSetWS2812FXMode(payload);
webSocket.sendTXT(num, "OK"); webSocket.sendTXT(num, "OK");
} }
// start auto cycling
if (strcmp((char *)payload, "start") == 0 ) {
handleAutoStart();
webSocket.sendTXT(num, "OK");
}
// stop auto cycling
if (strcmp((char *)payload, "stop") == 0 ) {
handleAutoStop();
webSocket.sendTXT(num, "OK");
}
break; break;
} }
} }

View file

@ -14,7 +14,8 @@
<body> <body>
<nav class="blue light-blueXXX lighten-1XXX" role="navigation" id="mc-nav"> <nav class="blue light-blueXXX lighten-1XXX" role="navigation" id="mc-nav">
<div class="nav-wrapper container"><a id="logo-container" href="#" class="brand-logo">Mc Lighting v2</a> <div class="nav-wrapper container">
<a id="logo-container" href="#" class="brand-logo">Mc Lighting v2</a>
<ul class="right hide-on-med-and-down"> <ul class="right hide-on-med-and-down">
<li><a href="#" class="mc-navlink" data-pane="pane1">Wheel</a></li> <li><a href="#" class="mc-navlink" data-pane="pane1">Wheel</a></li>
<li><a href="#" class="mc-navlink" data-pane="pane2">Modes</a></li> <li><a href="#" class="mc-navlink" data-pane="pane2">Modes</a></li>
@ -23,7 +24,6 @@
<ul id="nav-mobile" class="side-nav"> <ul id="nav-mobile" class="side-nav">
<li><a href="#" class="mc-navlink" data-pane="pane1">Wheel</a></li> <li><a href="#" class="mc-navlink" data-pane="pane1">Wheel</a></li>
<li><a href="#" class="mc-navlink" data-pane="pane2">Modes</a></li> <li><a href="#" class="mc-navlink" data-pane="pane2">Modes</a></li>
</ul> </ul>
<a href="#" data-activates="nav-mobile" class="button-collapse"><i class="material-icons">menu</i></a> <a href="#" data-activates="nav-mobile" class="button-collapse"><i class="material-icons">menu</i></a>
</div> </div>
@ -67,6 +67,11 @@
<div id="status_pos">pick a color</div> <div id="status_pos">pick a color</div>
<div id="status_color"></div> <div id="status_color"></div>
</div> </div>
<div class="right switch">Auto:<br>
<label>Off
<input id="autoSwitch" type="checkbox"><span class="lever"></span>On
</label>
</div>
</div> </div>
</div> </div>
</div> </div>
@ -108,13 +113,13 @@
</div> </div>
<div class="row"> <div class="row">
<div class="col s12 m6 l4 btn_grid"> <div class="col s12 m6 l6 btn_grid">
<a class="btn waves-effect waves-light btn_mode_static blue" name="action" data-mode="off">OFF <a class="btn waves-effect waves-light btn_mode_static blue" name="action" data-mode="off">OFF
<i class="material-icons right">send</i> <i class="material-icons right">send</i>
</a> </a>
</div> </div>
<div class="col s12 m6 l4 btn_grid"> <div class="col s12 m6 l6 btn_grid">
<a class="btn waves-effect waves-light btn_mode_static blue" name="action" data-mode="tv">TV <a class="btn waves-effect waves-light btn_mode_static blue" name="action" data-mode="tv">TV
<i class="material-icons right">send</i> <i class="material-icons right">send</i>
</a> </a>
@ -193,8 +198,9 @@ $(function(){
var modes_html = ""; var modes_html = "";
data.forEach(function(current_mode){ data.forEach(function(current_mode){
if (current_mode.mode !== undefined) { if (current_mode.mode !== undefined) {
modes_html += '<div class="col s12 m6 l4 btn_grid">'; modes_html += '<div class="col s12 m6 l6 btn_grid">';
modes_html += '<a class="btn waves-effect waves-light btn_mode blue" name="action" data-mode="' + current_mode.mode + '">' + current_mode.name + ''; modes_html += '<a class="btn waves-effect waves-light btn_mode blue" name="action" data-mode="' +
current_mode.mode + '">(' + current_mode.mode +') '+ current_mode.name;
modes_html += '<i class="material-icons right">send</i>'; modes_html += '<i class="material-icons right">send</i>';
modes_html += '</a>'; modes_html += '</a>';
modes_html += '</div>'; modes_html += '</div>';
@ -261,7 +267,15 @@ $(function(){
wsSendCommand("%" + brightness); wsSendCommand("%" + brightness);
}); });
$("#autoSwitch").on("change",function() {
if($(this).prop('checked')) {
wsSendCommand("start");
} else {
wsSendCommand("stop");
}
});
function setMode(mode, finish_funtion) { function setMode(mode, finish_funtion) {
console.log("Mode: ", mode); console.log("Mode: ", mode);
@ -401,7 +415,7 @@ $(function(){
$('#status').css("backgroundColor", hexColor); $('#status').css("backgroundColor", hexColor);
$('#status_color').text(hexColor + " - R=" + color[0] + ", G=" + color[1] + ", B=" + color[2]); $('#status_color').text(hexColor + " - R=" + color[0] + ", G=" + color[1] + ", B=" + color[2]);
$('#status_pos').text("x: " + pos.x + " - y: " + pos.y); $('#status_pos').text("x: " + pos.x + " - y: " + pos.y);
$("#rng_red").val(color[0]); $("#rng_red").val(color[0]);
$("#rng_green").val(color[1]); $("#rng_green").val(color[1]);
$("#rng_blue").val(color[2]); $("#rng_blue").val(color[2]);