Feature: Turn off LEDs before reboot
Thanks for the idea to @StefanOberhumer This prevents always on LEDs if the device profile does not contain LEDs pins anymore after the reboot
This commit is contained in:
parent
77a90095d9
commit
c91bd42a77
@ -19,6 +19,9 @@ public:
|
||||
void init();
|
||||
void loop();
|
||||
|
||||
void turnAllOff();
|
||||
void turnAllOn();
|
||||
|
||||
private:
|
||||
enum class LedState_t {
|
||||
On,
|
||||
@ -27,6 +30,7 @@ private:
|
||||
};
|
||||
|
||||
LedState_t _ledState[PINMAPPING_LED_COUNT];
|
||||
LedState_t _allState;
|
||||
TimeoutHelper _updateTimeout;
|
||||
TimeoutHelper _blinkTimeout;
|
||||
uint8_t _ledActive = 0;
|
||||
|
||||
@ -20,6 +20,7 @@ void LedSingleClass::init()
|
||||
{
|
||||
_blinkTimeout.set(500);
|
||||
_updateTimeout.set(LEDSINGLE_UPDATE_INTERVAL);
|
||||
turnAllOn();
|
||||
|
||||
for (uint8_t i = 0; i < PINMAPPING_LED_COUNT; i++) {
|
||||
auto& pin = PinMapping.get();
|
||||
@ -40,7 +41,7 @@ void LedSingleClass::loop()
|
||||
return;
|
||||
}
|
||||
|
||||
if (_updateTimeout.occured()) {
|
||||
if (_updateTimeout.occured() && _allState == LedState_t::On) {
|
||||
const CONFIG_T& config = Configuration.get();
|
||||
|
||||
// Update network status
|
||||
@ -68,6 +69,9 @@ void LedSingleClass::loop()
|
||||
}
|
||||
|
||||
_updateTimeout.reset();
|
||||
} else if (_updateTimeout.occured() && _allState == LedState_t::Off) {
|
||||
_ledState[0] = LedState_t::Off;
|
||||
_ledState[1] = LedState_t::Off;
|
||||
}
|
||||
|
||||
for (uint8_t i = 0; i < PINMAPPING_LED_COUNT; i++) {
|
||||
@ -93,3 +97,13 @@ void LedSingleClass::loop()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void LedSingleClass::turnAllOff()
|
||||
{
|
||||
_allState = LedState_t::Off;
|
||||
}
|
||||
|
||||
void LedSingleClass::turnAllOn()
|
||||
{
|
||||
_allState = LedState_t::On;
|
||||
}
|
||||
|
||||
@ -3,6 +3,7 @@
|
||||
* Copyright (C) 2022 - 2023 Thomas Basler and others
|
||||
*/
|
||||
#include "Utils.h"
|
||||
#include "Led_Single.h"
|
||||
#include <Esp.h>
|
||||
|
||||
uint32_t Utils::getChipId()
|
||||
@ -56,6 +57,7 @@ int Utils::getTimezoneOffset()
|
||||
|
||||
void Utils::restartDtu()
|
||||
{
|
||||
LedSingle.turnAllOff();
|
||||
yield();
|
||||
delay(1000);
|
||||
yield();
|
||||
|
||||
Loading…
Reference in New Issue
Block a user