Корректируем работу таймера с учетом возможности сохранения

состояния
This commit is contained in:
2022-10-20 00:15:08 +03:00
parent f3389c4721
commit 6c0a456fd0

View File

@@ -9,7 +9,6 @@ class Timer : public IoTItem {
bool _unfin = false;
bool _ticker = false;
bool _repeat = false;
bool _needSave = false;
bool _pause = false;
int _initValue;
@@ -17,20 +16,20 @@ class Timer : public IoTItem {
Timer(String parameters): IoTItem(parameters) {
jsonRead(parameters, "countDown", _initValue);
_unfin = !_initValue;
value.valD = _initValue;
if (_initValue) value.valD = value.valD + 1; // +1 - компенсируем ранний вычет счетчика, ранний вычет, чтоб после события значение таймера не исказилось.
// +0 - если изначально установили бесконечный счет
if (!_needSave) {
value.valD = _initValue;
if (_initValue) value.valD = value.valD + 1; // +1 - компенсируем ранний вычет счетчика, ранний вычет, чтоб после события значение таймера не исказилось.
}
jsonRead(parameters, "ticker", _ticker);
jsonRead(parameters, "repeat", _repeat);
jsonRead(parameters, "needSave", _needSave); // нужно сохранять счетчик в постоянную память
}
void doByInterval() {
if (!_unfin && value.valD >= 0 && !_pause) {
if (_repeat && value.valD == 0) value.valD = _initValue;
value.valD--;
if (_needSave) needSave = true;
if (value.valD == 0) {
regEvent(value.valD, "Time's up");
}