mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-30 11:59:12 +03:00
Корректируем работу таймера с учетом возможности сохранения
состояния
This commit is contained in:
@@ -9,7 +9,6 @@ class Timer : public IoTItem {
|
|||||||
bool _unfin = false;
|
bool _unfin = false;
|
||||||
bool _ticker = false;
|
bool _ticker = false;
|
||||||
bool _repeat = false;
|
bool _repeat = false;
|
||||||
bool _needSave = false;
|
|
||||||
bool _pause = false;
|
bool _pause = false;
|
||||||
int _initValue;
|
int _initValue;
|
||||||
|
|
||||||
@@ -17,20 +16,20 @@ class Timer : public IoTItem {
|
|||||||
Timer(String parameters): IoTItem(parameters) {
|
Timer(String parameters): IoTItem(parameters) {
|
||||||
jsonRead(parameters, "countDown", _initValue);
|
jsonRead(parameters, "countDown", _initValue);
|
||||||
_unfin = !_initValue;
|
_unfin = !_initValue;
|
||||||
|
|
||||||
|
if (!_needSave) {
|
||||||
value.valD = _initValue;
|
value.valD = _initValue;
|
||||||
if (_initValue) value.valD = value.valD + 1; // +1 - компенсируем ранний вычет счетчика, ранний вычет, чтоб после события значение таймера не исказилось.
|
if (_initValue) value.valD = value.valD + 1; // +1 - компенсируем ранний вычет счетчика, ранний вычет, чтоб после события значение таймера не исказилось.
|
||||||
// +0 - если изначально установили бесконечный счет
|
}
|
||||||
|
|
||||||
jsonRead(parameters, "ticker", _ticker);
|
jsonRead(parameters, "ticker", _ticker);
|
||||||
jsonRead(parameters, "repeat", _repeat);
|
jsonRead(parameters, "repeat", _repeat);
|
||||||
jsonRead(parameters, "needSave", _needSave); // нужно сохранять счетчик в постоянную память
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void doByInterval() {
|
void doByInterval() {
|
||||||
if (!_unfin && value.valD >= 0 && !_pause) {
|
if (!_unfin && value.valD >= 0 && !_pause) {
|
||||||
if (_repeat && value.valD == 0) value.valD = _initValue;
|
if (_repeat && value.valD == 0) value.valD = _initValue;
|
||||||
value.valD--;
|
value.valD--;
|
||||||
if (_needSave) needSave = true;
|
|
||||||
if (value.valD == 0) {
|
if (value.valD == 0) {
|
||||||
regEvent(value.valD, "Time's up");
|
regEvent(value.valD, "Time's up");
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user