Добавлена возможность смены ESP_MODE без перепрошивки; доработан будильник; добавлена визуальная сигнализация красными и жёлтыми вспышками для некоторых действий/состояний; оптимизирован код, исправлены ошибки

This commit is contained in:
gunner47
2019-10-12 19:52:04 +03:00
parent baa82236ee
commit 33c811ab59
13 changed files with 469 additions and 363 deletions

View File

@@ -6,9 +6,9 @@ static bool startButtonHolding = false; // флаг: кно
void buttonTick()
{
touch.tick();
uint8_t clickCount = touch.hasClicks() ? touch.getClicks() : 0;
uint8_t clickCount = touch.hasClicks() ? touch.getClicks() : 0U;
if (clickCount == 1)
if (clickCount == 1U)
{
if (dawnFlag)
{
@@ -26,14 +26,17 @@ void buttonTick()
eepromTimeout = millis();
loadingFlag = true;
#if (USE_MQTT && ESP_MODE == 1)
MqttManager::needToPublish = true;
#if (USE_MQTT)
if (espMode == 1U)
{
MqttManager::needToPublish = true;
}
#endif
}
if (ONflag && clickCount == 2)
if (ONflag && clickCount == 2U)
{
if (++currentMode >= MODE_AMOUNT) currentMode = 0;
if (++currentMode >= (int8_t)MODE_AMOUNT) currentMode = 0;
FastLED.setBrightness(modes[currentMode].Brightness);
loadingFlag = true;
settChanged = true;
@@ -41,12 +44,15 @@ void buttonTick()
FastLED.clear();
delay(1);
#if (USE_MQTT && ESP_MODE == 1)
MqttManager::needToPublish = true;
#if (USE_MQTT)
if (espMode == 1U)
{
MqttManager::needToPublish = true;
}
#endif
}
if (ONflag && clickCount == 3)
if (ONflag && clickCount == 3U)
{
if (--currentMode < 0) currentMode = MODE_AMOUNT - 1;
FastLED.setBrightness(modes[currentMode].Brightness);
@@ -56,26 +62,31 @@ void buttonTick()
FastLED.clear();
delay(1);
#if (USE_MQTT && ESP_MODE == 1)
MqttManager::needToPublish = true;
#endif
}
if (clickCount == 4)
{
#ifdef OTA
if (otaManager.RequestOtaUpdate())
#if (USE_MQTT)
if (espMode == 1U)
{
currentMode = EFF_MATRIX; // принудительное включение режима "Матрица" для индикации перехода в режим обновления по воздуху
FastLED.clear();
delay(1);
MqttManager::needToPublish = true;
}
#endif
}
if (ONflag && clickCount == 5) // вывод IP на лампу
if (clickCount == 4U)
{
if (ESP_MODE == 1U)
#ifdef OTA
if (otaManager.RequestOtaUpdate())
{
ONflag = true;
currentMode = EFF_MATRIX; // принудительное включение режима "Матрица" для индикации перехода в режим обновления по воздуху
FastLED.clear();
delay(1);
changePower();
}
#endif
}
if (ONflag && clickCount == 5U) // вывод IP на лампу
{
if (espMode == 1U)
{
loadingFlag = true;
while(!fillString(WiFi.localIP().toString().c_str())) delay(1);
@@ -83,6 +94,22 @@ void buttonTick()
}
}
if (ONflag && clickCount == 7U) // смена рабочего режима лампы: с WiFi точки доступа на WiFi клиент или наоборот
{
espMode = (espMode == 0U) ? 1U : 0U;
EepromManager::SaveEspMode(&espMode);
#ifdef GENERAL_DEBUG
LOG.printf_P(PSTR("Рабочий режим лампы изменён и сохранён в энергонезависимую память\nНовый рабочий режим: ESP_MODE = %d, %s\nРестарт...\n"),
espMode, espMode == 0U ? F("WiFi точка доступа") : F("WiFi клиент (подключение к роутеру)"));
delay(1000);
#endif
showWarning(CRGB::Red, 3000U, 500U); // мигание красным цветом 3 секунды - смена рабочего режима лампы, перезагрузка
ESP.restart();
}
if (ONflag && touch.isHolded())
{
brightDirection = !brightDirection;
@@ -91,9 +118,9 @@ void buttonTick()
if (ONflag && touch.isStep())
{
uint8_t delta = modes[currentMode].Brightness < 10 // определение шага изменения яркости: при яркости [1..10] шаг = 1, при [11..16] шаг = 3, при [17..255] шаг = 15
? 1
: 5;
uint8_t delta = modes[currentMode].Brightness < 10U // определение шага изменения яркости: при яркости [1..10] шаг = 1, при [11..16] шаг = 3, при [17..255] шаг = 15
? 1U
: 5U;
modes[currentMode].Brightness =
constrain(brightDirection
? modes[currentMode].Brightness + delta
@@ -108,8 +135,8 @@ void buttonTick()
#endif
}
#if (USE_MQTT && ESP_MODE == 1)
if (ONflag && !touch.isHold() && startButtonHolding) // кнопка отпущена после удерживания, нужно отправить MQTT сообщение об изменении яркости лампы
#if (USE_MQTT)
if (espMode == 1U && ONflag && !touch.isHold() && startButtonHolding) // кнопка отпущена после удерживания, нужно отправить MQTT сообщение об изменении яркости лампы
{
MqttManager::needToPublish = true;
startButtonHolding = false;