Padded single digit LED identifiers to two chars (01,02 vs 1,2 etc)
This commit is contained in:
parent
7a059a1a14
commit
d5befdb3eb
1 changed files with 20 additions and 14 deletions
|
@ -18,7 +18,7 @@ void getArgs() {
|
||||||
}
|
}
|
||||||
|
|
||||||
ws2812fx_mode = constrain(server.arg("m").toInt(), 0, strip.getModeCount()-1);
|
ws2812fx_mode = constrain(server.arg("m").toInt(), 0, strip.getModeCount()-1);
|
||||||
|
|
||||||
main_color.red = constrain(main_color.red, 0, 255);
|
main_color.red = constrain(main_color.red, 0, 255);
|
||||||
main_color.green = constrain(main_color.green, 0, 255);
|
main_color.green = constrain(main_color.green, 0, 255);
|
||||||
main_color.blue = constrain(main_color.blue, 0, 255);
|
main_color.blue = constrain(main_color.blue, 0, 255);
|
||||||
|
@ -74,12 +74,12 @@ void handleSetSingleLED(uint8_t * mypayload, uint8_t firstChar = 1) {
|
||||||
strncpy ( templed, (const char *) &mypayload[firstChar], 2 );
|
strncpy ( templed, (const char *) &mypayload[firstChar], 2 );
|
||||||
uint8_t led = atoi(templed);
|
uint8_t led = atoi(templed);
|
||||||
|
|
||||||
if (led < strip.numPixels()) {
|
if (led <= strip.numPixels()) {
|
||||||
ledstates[led].red = ((rgb >> 16) & 0xFF);
|
ledstates[led].red = ((rgb >> 16) & 0xFF);
|
||||||
ledstates[led].green = ((rgb >> 8) & 0xFF);
|
ledstates[led].green = ((rgb >> 8) & 0xFF);
|
||||||
ledstates[led].blue = ((rgb >> 0) & 0xFF);
|
ledstates[led].blue = ((rgb >> 0) & 0xFF);
|
||||||
DBG_OUTPUT_PORT.printf("WS: Set single led [%u] to [%u] [%u] [%u] (%s)!\n", led, ledstates[led].red, ledstates[led].green, ledstates[led].blue, mypayload);
|
DBG_OUTPUT_PORT.printf("WS: Set single led [%u] to [%u] [%u] [%u] (%s)!\n", led, ledstates[led].red, ledstates[led].green, ledstates[led].blue, mypayload);
|
||||||
|
|
||||||
for (uint8_t i = 0; i < strip.numPixels(); i++) {
|
for (uint8_t i = 0; i < strip.numPixels(); i++) {
|
||||||
strip.setPixelColor(i, ledstates[i].red, ledstates[i].green, ledstates[i].blue);
|
strip.setPixelColor(i, ledstates[i].red, ledstates[i].green, ledstates[i].blue);
|
||||||
//DBG_OUTPUT_PORT.printf("[%u]--[%u] [%u] [%u] [%u] LED index!\n", rgb, i, ledstates[i].red, ledstates[i].green, ledstates[i].blue);
|
//DBG_OUTPUT_PORT.printf("[%u]--[%u] [%u] [%u] [%u] LED index!\n", rgb, i, ledstates[i].red, ledstates[i].green, ledstates[i].blue);
|
||||||
|
@ -118,8 +118,14 @@ void handleRangeDifferentColors(uint8_t * mypayload) {
|
||||||
|
|
||||||
while ( rangebegin <= rangeend ) {
|
while ( rangebegin <= rangeend ) {
|
||||||
char rangeData[9] = { 0,0,0,0,0,0,0,0,0 };
|
char rangeData[9] = { 0,0,0,0,0,0,0,0,0 };
|
||||||
//Create the valid 'nextCommand' structure
|
if ( rangebegin < 10 ) {
|
||||||
sprintf(rangeData, "%d%s", rangebegin, colorval);
|
//Create the valid 'nextCommand' structure
|
||||||
|
sprintf(rangeData, "0%d%s", rangebegin, colorval);
|
||||||
|
}
|
||||||
|
if ( rangebegin >= 10 ) {
|
||||||
|
//Create the valid 'nextCommand' structure
|
||||||
|
sprintf(rangeData, "%d%s", rangebegin, colorval);
|
||||||
|
}
|
||||||
//Set one LED
|
//Set one LED
|
||||||
handleSetSingleLED((uint8_t*) rangeData, 0);
|
handleSetSingleLED((uint8_t*) rangeData, 0);
|
||||||
rangebegin++;
|
rangebegin++;
|
||||||
|
@ -132,7 +138,7 @@ void handleRangeDifferentColors(uint8_t * mypayload) {
|
||||||
|
|
||||||
void handleSetNamedMode(String str_mode) {
|
void handleSetNamedMode(String str_mode) {
|
||||||
exit_func = true;
|
exit_func = true;
|
||||||
|
|
||||||
if (str_mode.startsWith("=off")) {
|
if (str_mode.startsWith("=off")) {
|
||||||
mode = OFF;
|
mode = OFF;
|
||||||
}
|
}
|
||||||
|
@ -354,21 +360,21 @@ void webSocketEvent(uint8_t num, WStype_t type, uint8_t * payload, size_t lenght
|
||||||
// $ ==> Get status Info.
|
// $ ==> Get status Info.
|
||||||
if (payload[0] == '$') {
|
if (payload[0] == '$') {
|
||||||
DBG_OUTPUT_PORT.printf("Get status info.");
|
DBG_OUTPUT_PORT.printf("Get status info.");
|
||||||
|
|
||||||
String json = listStatusJSON();
|
String json = listStatusJSON();
|
||||||
DBG_OUTPUT_PORT.println(json);
|
DBG_OUTPUT_PORT.println(json);
|
||||||
webSocket.sendTXT(num, json);
|
webSocket.sendTXT(num, json);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ~ ==> Get WS2812 modes.
|
// ~ ==> Get WS2812 modes.
|
||||||
if (payload[0] == '~') {
|
if (payload[0] == '~') {
|
||||||
DBG_OUTPUT_PORT.printf("Get WS2812 modes.");
|
DBG_OUTPUT_PORT.printf("Get WS2812 modes.");
|
||||||
|
|
||||||
String json = listModesJSON();
|
String json = listModesJSON();
|
||||||
DBG_OUTPUT_PORT.println(json);
|
DBG_OUTPUT_PORT.println(json);
|
||||||
webSocket.sendTXT(num, json);
|
webSocket.sendTXT(num, json);
|
||||||
}
|
}
|
||||||
|
|
||||||
// / ==> Set WS2812 mode.
|
// / ==> Set WS2812 mode.
|
||||||
if (payload[0] == '/') {
|
if (payload[0] == '/') {
|
||||||
handleSetWS2812FXMode(payload);
|
handleSetWS2812FXMode(payload);
|
||||||
|
@ -481,11 +487,11 @@ void checkForRequests() {
|
||||||
mqtt_client.publish(mqtt_outtopic, "ERROR: Not implemented. Message too large for pubsubclient.");
|
mqtt_client.publish(mqtt_outtopic, "ERROR: Not implemented. Message too large for pubsubclient.");
|
||||||
//String json_modes = listModesJSON();
|
//String json_modes = listModesJSON();
|
||||||
//DBG_OUTPUT_PORT.printf(json_modes.c_str());
|
//DBG_OUTPUT_PORT.printf(json_modes.c_str());
|
||||||
|
|
||||||
//int res = mqtt_client.publish(mqtt_outtopic, json_modes.c_str(), json_modes.length());
|
//int res = mqtt_client.publish(mqtt_outtopic, json_modes.c_str(), json_modes.length());
|
||||||
//DBG_OUTPUT_PORT.printf("Result: %d / %d", res, json_modes.length());
|
//DBG_OUTPUT_PORT.printf("Result: %d / %d", res, json_modes.length());
|
||||||
}
|
}
|
||||||
|
|
||||||
// / ==> Set WS2812 mode.
|
// / ==> Set WS2812 mode.
|
||||||
if (payload[0] == '/') {
|
if (payload[0] == '/') {
|
||||||
handleSetWS2812FXMode(payload);
|
handleSetWS2812FXMode(payload);
|
||||||
|
@ -495,7 +501,7 @@ void checkForRequests() {
|
||||||
|
|
||||||
free(payload);
|
free(payload);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mqtt_reconnect() {
|
void mqtt_reconnect() {
|
||||||
// Loop until we're reconnected
|
// Loop until we're reconnected
|
||||||
while (!mqtt_client.connected() && mqtt_reconnect_retries < MQTT_MAX_RECONNECT_TRIES) {
|
while (!mqtt_client.connected() && mqtt_reconnect_retries < MQTT_MAX_RECONNECT_TRIES) {
|
||||||
|
@ -525,5 +531,5 @@ void checkForRequests() {
|
||||||
if (mqtt_reconnect_retries >= MQTT_MAX_RECONNECT_TRIES) {
|
if (mqtt_reconnect_retries >= MQTT_MAX_RECONNECT_TRIES) {
|
||||||
DBG_OUTPUT_PORT.printf("MQTT connection failed, giving up after %d tries ...\n", mqtt_reconnect_retries);
|
DBG_OUTPUT_PORT.printf("MQTT connection failed, giving up after %d tries ...\n", mqtt_reconnect_retries);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue