From a2c9d2757b638b1fc2f7231860687517d67286db Mon Sep 17 00:00:00 2001 From: Stephan <31169771+Blueforcer@users.noreply.github.com> Date: Sun, 19 Nov 2023 21:06:23 +0100 Subject: [PATCH] fix bug where icons are closed randomly --- docs/apps.md | 6 +++--- src/Apps.cpp | 2 +- src/ArtnetWifi.h | 6 ------ src/DisplayManager.cpp | 41 +++++++++++++++-------------------------- 4 files changed, 19 insertions(+), 36 deletions(-) diff --git a/docs/apps.md b/docs/apps.md index 1d3317e1..f9c146e6 100644 --- a/docs/apps.md +++ b/docs/apps.md @@ -30,7 +30,7 @@ Here is a demo, please press the triangle to unfold.
Example for adding a Youtube App as NodeRED flow -```json +```json [ { "id": "2a59d30d07abe14f", @@ -200,8 +200,8 @@ Here is a demo, please press the triangle to unfold. "userProps": "", "sessionExpiry": "" } -] -``` +] +```
This Node-RED flow retrieves and displays the subscriber count of a specified YouTube channel on an AWTRIX light device. The flow consists of the following nodes: diff --git a/src/Apps.cpp b/src/Apps.cpp index b5d2dc03..1ec92c96 100644 --- a/src/Apps.cpp +++ b/src/Apps.cpp @@ -608,7 +608,7 @@ void ShowCustomApp(String name, FastLED_NeoMatrix *matrix, MatrixDisplayUiState DisplayManager.getInstance().resetTextColor(); } -// Unattractive to have a function for every customapp which does the same, but currently still no other option found TODO +// Unattractive to have a function for every customapp wich does the same, but currently still no other option found TODO void CApp1(FastLED_NeoMatrix *matrix, MatrixDisplayUiState *state, int16_t x, int16_t y, GifPlayer *gifPlayer) { diff --git a/src/ArtnetWifi.h b/src/ArtnetWifi.h index 9b39aa63..384ecf37 100644 --- a/src/ArtnetWifi.h +++ b/src/ArtnetWifi.h @@ -105,12 +105,6 @@ class ArtnetWifi physical = port; } - [[deprecated]] - inline void setPhysical(uint8_t port) - { - setPhysical(port); - } - inline uint16_t getLength(void) { return dmxDataLength; diff --git a/src/DisplayManager.cpp b/src/DisplayManager.cpp index 1e893cf0..4d9cd4b4 100644 --- a/src/DisplayManager.cpp +++ b/src/DisplayManager.cpp @@ -126,6 +126,11 @@ void DisplayManager_::applyAllSettings() setAutoTransition(AUTO_TRANSITION); } +void DisplayManager_::setAppTime(long duration) +{ + ui->setTimePerApp(duration); +} + void DisplayManager_::resetTextColor() { setTextColor(TEXTCOLOR_888); @@ -385,6 +390,7 @@ void removeCustomAppFromApps(const String &name, bool setApps) ui->setApps(Apps); DisplayManager.getInstance().setAutoTransition(true); deleteCustomAppFile(name); + DisplayManager.setAppTime(TIME_PER_APP); } bool parseFragmentsText(const JsonArray &fragmentArray, std::vector &colors, std::vector &fragments, uint32_t standardColor) @@ -613,35 +619,24 @@ bool DisplayManager_::generateCustomPage(const String &name, JsonObject doc, boo if (doc.containsKey("icon")) { - String iconValue = doc["icon"].as(); + String newIconName = doc["icon"].as(); - if (iconValue.endsWith("=")) + if (newIconName.endsWith("=")) { - customApp.jpegDataSize = decode_base64((const unsigned char *)iconValue.c_str(), customApp.jpegDataBuffer); + customApp.jpegDataSize = decode_base64((const unsigned char *)newIconName.c_str(), customApp.jpegDataBuffer); customApp.isGif = false; customApp.icon.close(); customApp.iconName = ""; customApp.iconPosition = 0; customApp.currentFrame = 0; } - else + else if (customApp.iconName != newIconName) { customApp.jpegDataSize = 0; - if (customApp.iconName != iconValue) - { - customApp.iconName = iconValue; - customApp.icon.close(); - customApp.iconPosition = 0; - customApp.currentFrame = 0; - } - - else - { - customApp.icon.close(); - customApp.iconName = ""; - customApp.iconPosition = 0; - customApp.currentFrame = 0; - } + customApp.iconName = newIconName; + customApp.icon.close(); + customApp.iconPosition = 0; + customApp.currentFrame = 0; } } else @@ -906,7 +901,6 @@ bool DisplayManager_::generateNotification(uint8_t source, const char *json) { String iconValue = doc["icon"].as(); - if (iconValue.endsWith("=")) { newNotification.jpegDataSize = decode_base64((const unsigned char *)iconValue.c_str(), newNotification.jpegDataBuffer); @@ -1222,7 +1216,7 @@ void DisplayManager_::tick() void onDmxFrame(uint16_t universe, uint16_t length, uint8_t sequence, uint8_t *data) { sendFrame = 1; - // set brightness of the whole strip + // set brightness of the whole matrix if (universe == 10) { matrix->setBrightness(data[0]); @@ -1595,11 +1589,6 @@ String DisplayManager_::getStats() return jsonString; } -void DisplayManager_::setAppTime(long duration) -{ - ui->setTimePerApp(duration); -} - void DisplayManager_::setMatrixLayout(int layout) { delete matrix; // Free memory from the current matrix object