e131 update + HA: sendState() update
- Stop strip when e131 is sent - sendState() needs extra memory for jsonBuffer - sensState() effect can be sent directly instead of copying from PROGMEM
This commit is contained in:
parent
1519ba81c4
commit
35b989e98d
2 changed files with 13 additions and 8 deletions
|
@ -357,8 +357,6 @@ void setup() {
|
||||||
strcpy(mqtt_user, custom_mqtt_user.getValue());
|
strcpy(mqtt_user, custom_mqtt_user.getValue());
|
||||||
strcpy(mqtt_pass, custom_mqtt_pass.getValue());
|
strcpy(mqtt_pass, custom_mqtt_pass.getValue());
|
||||||
|
|
||||||
Serial.printf(">>>>>%s %s %s %s<<<<<<<<<\n", mqtt_host, mqtt_port, mqtt_user, mqtt_pass);
|
|
||||||
|
|
||||||
//save the custom parameters to FS
|
//save the custom parameters to FS
|
||||||
#if defined(ENABLE_STATE_SAVE_SPIFFS) and (defined(ENABLE_MQTT) or defined(ENABLE_AMQTT))
|
#if defined(ENABLE_STATE_SAVE_SPIFFS) and (defined(ENABLE_MQTT) or defined(ENABLE_AMQTT))
|
||||||
(writeConfigFS(shouldSaveConfig)) ? DBG_OUTPUT_PORT.println("WiFiManager config FS Save success!"): DBG_OUTPUT_PORT.println("WiFiManager config FS Save failure!");
|
(writeConfigFS(shouldSaveConfig)) ? DBG_OUTPUT_PORT.println("WiFiManager config FS Save success!"): DBG_OUTPUT_PORT.println("WiFiManager config FS Save failure!");
|
||||||
|
|
|
@ -304,6 +304,7 @@ void setModeByStateString(String saved_state_string) {
|
||||||
void handleE131NamedMode(String str_mode) {
|
void handleE131NamedMode(String str_mode) {
|
||||||
exit_func = true;
|
exit_func = true;
|
||||||
if (str_mode.startsWith("=e131")) {
|
if (str_mode.startsWith("=e131")) {
|
||||||
|
if(strip.isRunning()) strip.stop();
|
||||||
mode = E131;
|
mode = E131;
|
||||||
#ifdef ENABLE_HOMEASSISTANT
|
#ifdef ENABLE_HOMEASSISTANT
|
||||||
stateOn = true;
|
stateOn = true;
|
||||||
|
@ -812,7 +813,7 @@ void webSocketEvent(uint8_t num, WStype_t type, uint8_t * payload, size_t lenght
|
||||||
}
|
}
|
||||||
|
|
||||||
void sendState() {
|
void sendState() {
|
||||||
const size_t bufferSize = JSON_OBJECT_SIZE(3) + JSON_OBJECT_SIZE(6);
|
const size_t bufferSize = JSON_OBJECT_SIZE(3) + JSON_OBJECT_SIZE(6) + 500;
|
||||||
DynamicJsonDocument jsonBuffer(bufferSize);
|
DynamicJsonDocument jsonBuffer(bufferSize);
|
||||||
JsonObject root = jsonBuffer.to<JsonObject>();
|
JsonObject root = jsonBuffer.to<JsonObject>();
|
||||||
|
|
||||||
|
@ -828,9 +829,9 @@ void webSocketEvent(uint8_t num, WStype_t type, uint8_t * payload, size_t lenght
|
||||||
|
|
||||||
root["speed"] = ws2812fx_speed;
|
root["speed"] = ws2812fx_speed;
|
||||||
|
|
||||||
char modeName[30];
|
//char modeName[30];
|
||||||
strncpy_P(modeName, (PGM_P)strip.getModeName(strip.getMode()), sizeof(modeName)); // copy from progmem
|
//strncpy_P(modeName, (PGM_P)strip.getModeName(strip.getMode()), sizeof(modeName)); // copy from progmem
|
||||||
root["effect"] = modeName;
|
root["effect"] = strip.getModeName(strip.getMode());
|
||||||
|
|
||||||
char buffer[measureJson(root) + 1];
|
char buffer[measureJson(root) + 1];
|
||||||
serializeJson(root, buffer, sizeof(buffer));
|
serializeJson(root, buffer, sizeof(buffer));
|
||||||
|
@ -1322,7 +1323,7 @@ bool writeStateFS(){
|
||||||
json["green"] = main_color.green;
|
json["green"] = main_color.green;
|
||||||
json["blue"] = main_color.blue;
|
json["blue"] = main_color.blue;
|
||||||
|
|
||||||
// SPIFFS.remove("/state.json") ? DBG_OUTPUT_PORT.println("removed file") : DBG_OUTPUT_PORT.println("failed removing file");
|
//SPIFFS.remove("/stripstate.json") ? DBG_OUTPUT_PORT.println("removed file") : DBG_OUTPUT_PORT.println("failed removing file");
|
||||||
File configFile = SPIFFS.open("/stripstate.json", "w");
|
File configFile = SPIFFS.open("/stripstate.json", "w");
|
||||||
if (!configFile) {
|
if (!configFile) {
|
||||||
DBG_OUTPUT_PORT.println("Failed!");
|
DBG_OUTPUT_PORT.println("Failed!");
|
||||||
|
@ -1372,6 +1373,12 @@ bool readStateFS() {
|
||||||
strip.setBrightness(brightness);
|
strip.setBrightness(brightness);
|
||||||
strip.setColor(main_color.red, main_color.green, main_color.blue);
|
strip.setColor(main_color.red, main_color.green, main_color.blue);
|
||||||
|
|
||||||
|
#ifdef ENABLE_E131
|
||||||
|
if (mode == E131) {
|
||||||
|
strip.stop();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
updateFS = false;
|
updateFS = false;
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue