mirror of
https://github.com/gunner47/GyverLamp.git
synced 2025-08-08 09:20:59 +03:00
Изменено управление кнопкой: удержание - изменение яркости, 1 клик + удержание - изменение скорости, 2 клика + удержание - изменение масштаба
This commit is contained in:
@@ -8,12 +8,16 @@
|
|||||||
#define ESP_MODE (1U) // 0U - WiFi точка доступа, 1U - клиент WiFi (подключение к роутеру)
|
#define ESP_MODE (1U) // 0U - WiFi точка доступа, 1U - клиент WiFi (подключение к роутеру)
|
||||||
uint8_t espMode = ESP_MODE; // ESP_MODE может быть сохранён в энергонезависимую память и изменён в процессе работы лампы без необходимости её перепрошивки
|
uint8_t espMode = ESP_MODE; // ESP_MODE может быть сохранён в энергонезависимую память и изменён в процессе работы лампы без необходимости её перепрошивки
|
||||||
#define ESP_USE_BUTTON // если строка не закомментирована, должна быть подключена кнопка (иначе ESP может регистрировать "фантомные" нажатия и некорректно устанавливать яркость)
|
#define ESP_USE_BUTTON // если строка не закомментирована, должна быть подключена кнопка (иначе ESP может регистрировать "фантомные" нажатия и некорректно устанавливать яркость)
|
||||||
|
#if defined (ESP_USE_BUTTON)
|
||||||
|
#define BUTTON_STEP_TIMEOUT (100U) // каждые BUTTON_STEP_TIMEOUT мс будет генерироваться событие удержания кнопки (для регулировки яркости)
|
||||||
|
#define BUTTON_CLICK_TIMEOUT (500U) // максимальное время между нажатиями кнопки в мс, до достижения которого считается серия последовательных нажатий
|
||||||
|
#endif
|
||||||
#define ESP_RESET_ON_START (false) // true - если при старте нажата кнопка (или кнопки нет!), сохранённые настройки будут сброшены; false - не будут
|
#define ESP_RESET_ON_START (false) // true - если при старте нажата кнопка (или кнопки нет!), сохранённые настройки будут сброшены; false - не будут
|
||||||
#define ESP_HTTP_PORT (80U) // номер порта, который будет использоваться во время первой утановки имени WiFi сети (и пароля), к которой потом будет подключаться лампа в режиме WiFi клиента (лучше не менять)
|
#define ESP_HTTP_PORT (80U) // номер порта, который будет использоваться во время первой утановки имени WiFi сети (и пароля), к которой потом будет подключаться лампа в режиме WiFi клиента (лучше не менять)
|
||||||
#define ESP_UDP_PORT (8888U) // номер порта, который будет "слушать" UDP сервер во время работы лампы как в режиме WiFi точки доступа, так и в режиме WiFi клиента (лучше не менять)
|
#define ESP_UDP_PORT (8888U) // номер порта, который будет "слушать" UDP сервер во время работы лампы как в режиме WiFi точки доступа, так и в режиме WiFi клиента (лучше не менять)
|
||||||
#define ESP_CONN_TIMEOUT (7U) // время в секундах (ДОЛЖНО БЫТЬ МЕНЬШЕ 8, иначе сработает WDT), которое ESP будет пытаться подключиться к WiFi сети, после его истечения автоматически развернёт WiFi точку доступа
|
#define ESP_CONN_TIMEOUT (7U) // время в секундах (ДОЛЖНО БЫТЬ МЕНЬШЕ 8, иначе сработает WDT), которое ESP будет пытаться подключиться к WiFi сети, после его истечения автоматически развернёт WiFi точку доступа
|
||||||
#define ESP_CONF_TIMEOUT (300U) // время в секундах, которое ESP будет ждать ввода SSID и пароля WiFi сети роутера в конфигурационном режиме, после его истечения ESP перезагружается
|
#define ESP_CONF_TIMEOUT (300U) // время в секундах, которое ESP будет ждать ввода SSID и пароля WiFi сети роутера в конфигурационном режиме, после его истечения ESP перезагружается
|
||||||
#define GENERAL_DEBUG // если строка не закомментирована, будут выводиться отладочные сообщения
|
//#define GENERAL_DEBUG // если строка не закомментирована, будут выводиться отладочные сообщения
|
||||||
#define WIFIMAN_DEBUG (true) // вывод отладочных сообщений при подключении к WiFi сети: true - выводятся, false - не выводятся; настройка не зависит от GENERAL_DEBUG
|
#define WIFIMAN_DEBUG (true) // вывод отладочных сообщений при подключении к WiFi сети: true - выводятся, false - не выводятся; настройка не зависит от GENERAL_DEBUG
|
||||||
#define OTA // если строка не закомментирована, модуль будет ждать два последдовательных запроса пользователя на прошивку по воздуху (см. документацию в "шапке")
|
#define OTA // если строка не закомментирована, модуль будет ждать два последдовательных запроса пользователя на прошивку по воздуху (см. документацию в "шапке")
|
||||||
#ifdef OTA
|
#ifdef OTA
|
||||||
|
@@ -224,8 +224,8 @@ void setup()
|
|||||||
|
|
||||||
// КНОПКА
|
// КНОПКА
|
||||||
#if defined(ESP_USE_BUTTON)
|
#if defined(ESP_USE_BUTTON)
|
||||||
touch.setStepTimeout(100);
|
touch.setStepTimeout(BUTTON_STEP_TIMEOUT);
|
||||||
touch.setClickTimeout(500);
|
touch.setClickTimeout(BUTTON_CLICK_TIMEOUT);
|
||||||
#if ESP_RESET_ON_START
|
#if ESP_RESET_ON_START
|
||||||
delay(1000); // ожидание инициализации модуля кнопки ttp223 (по спецификации 250мс)
|
delay(1000); // ожидание инициализации модуля кнопки ttp223 (по спецификации 250мс)
|
||||||
if (digitalRead(BTN_PIN))
|
if (digitalRead(BTN_PIN))
|
||||||
|
@@ -1,13 +1,16 @@
|
|||||||
#ifdef ESP_USE_BUTTON
|
#ifdef ESP_USE_BUTTON
|
||||||
bool brightDirection;
|
|
||||||
|
|
||||||
static bool startButtonHolding = false; // флаг: кнопка удерживается для изменения яркости лампы
|
bool brightDirection;
|
||||||
|
static bool startButtonHolding = false; // флаг: кнопка удерживается для изменения яркости/скорости/масштаба лампы кнопкой
|
||||||
|
|
||||||
|
|
||||||
void buttonTick()
|
void buttonTick()
|
||||||
{
|
{
|
||||||
touch.tick();
|
touch.tick();
|
||||||
uint8_t clickCount = touch.hasClicks() ? touch.getClicks() : 0U;
|
uint8_t clickCount = touch.hasClicks() ? touch.getClicks() : 0U;
|
||||||
|
|
||||||
|
|
||||||
|
// однократное нажатие
|
||||||
if (clickCount == 1U)
|
if (clickCount == 1U)
|
||||||
{
|
{
|
||||||
if (dawnFlag)
|
if (dawnFlag)
|
||||||
@@ -34,6 +37,8 @@ void buttonTick()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// двухкратное нажатие
|
||||||
if (ONflag && clickCount == 2U)
|
if (ONflag && clickCount == 2U)
|
||||||
{
|
{
|
||||||
if (++currentMode >= (int8_t)MODE_AMOUNT) currentMode = 0;
|
if (++currentMode >= (int8_t)MODE_AMOUNT) currentMode = 0;
|
||||||
@@ -52,6 +57,8 @@ void buttonTick()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// трёхкратное нажатие
|
||||||
if (ONflag && clickCount == 3U)
|
if (ONflag && clickCount == 3U)
|
||||||
{
|
{
|
||||||
if (--currentMode < 0) currentMode = MODE_AMOUNT - 1;
|
if (--currentMode < 0) currentMode = MODE_AMOUNT - 1;
|
||||||
@@ -70,6 +77,8 @@ void buttonTick()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// четырёхкратное нажатие
|
||||||
if (clickCount == 4U)
|
if (clickCount == 4U)
|
||||||
{
|
{
|
||||||
#ifdef OTA
|
#ifdef OTA
|
||||||
@@ -84,6 +93,8 @@ void buttonTick()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// пятикратное нажатие
|
||||||
if (clickCount == 5U) // вывод IP на лампу
|
if (clickCount == 5U) // вывод IP на лампу
|
||||||
{
|
{
|
||||||
if (espMode == 1U)
|
if (espMode == 1U)
|
||||||
@@ -94,11 +105,15 @@ void buttonTick()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// шестикратное нажатие
|
||||||
if (clickCount == 6U) // вывод текущего времени бегущей строкой
|
if (clickCount == 6U) // вывод текущего времени бегущей строкой
|
||||||
{
|
{
|
||||||
printTime(thisTime, true);
|
printTime(thisTime, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// семикратное нажатие
|
||||||
if (ONflag && clickCount == 7U) // смена рабочего режима лампы: с WiFi точки доступа на WiFi клиент или наоборот
|
if (ONflag && clickCount == 7U) // смена рабочего режима лампы: с WiFi точки доступа на WiFi клиент или наоборот
|
||||||
{
|
{
|
||||||
espMode = (espMode == 0U) ? 1U : 0U;
|
espMode = (espMode == 0U) ? 1U : 0U;
|
||||||
@@ -115,13 +130,20 @@ void buttonTick()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// кнопка только начала удерживаться
|
||||||
if (ONflag && touch.isHolded())
|
if (ONflag && touch.isHolded())
|
||||||
{
|
{
|
||||||
brightDirection = !brightDirection;
|
brightDirection = !brightDirection;
|
||||||
startButtonHolding = true;
|
startButtonHolding = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// кнопка нажата и удерживается
|
||||||
if (ONflag && touch.isStep())
|
if (ONflag && touch.isStep())
|
||||||
|
{
|
||||||
|
switch (touch.getHoldClicks())
|
||||||
|
{
|
||||||
|
case 0U: // просто удержание (до удержания кнопки кликов не было) - изменение яркости
|
||||||
{
|
{
|
||||||
uint8_t delta = modes[currentMode].Brightness < 10U // определение шага изменения яркости: при яркости [1..10] шаг = 1, при [11..16] шаг = 3, при [17..255] шаг = 15
|
uint8_t delta = modes[currentMode].Brightness < 10U // определение шага изменения яркости: при яркости [1..10] шаг = 1, при [11..16] шаг = 3, при [17..255] шаг = 15
|
||||||
? 1U
|
? 1U
|
||||||
@@ -132,20 +154,57 @@ void buttonTick()
|
|||||||
: modes[currentMode].Brightness - delta,
|
: modes[currentMode].Brightness - delta,
|
||||||
1, 255);
|
1, 255);
|
||||||
FastLED.setBrightness(modes[currentMode].Brightness);
|
FastLED.setBrightness(modes[currentMode].Brightness);
|
||||||
settChanged = true;
|
|
||||||
eepromTimeout = millis();
|
|
||||||
|
|
||||||
#ifdef GENERAL_DEBUG
|
#ifdef GENERAL_DEBUG
|
||||||
LOG.printf_P(PSTR("New brightness value: %d\n"), modes[currentMode].Brightness);
|
LOG.printf_P(PSTR("Новое значение яркости: %d\n"), modes[currentMode].Brightness);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case 1U: // удержание после одного клика - изменение скорости
|
||||||
|
{
|
||||||
|
modes[currentMode].Speed = constrain(brightDirection ? modes[currentMode].Speed + 1 : modes[currentMode].Speed - 1, 1, 255);
|
||||||
|
|
||||||
|
#ifdef GENERAL_DEBUG
|
||||||
|
LOG.printf_P(PSTR("Новое значение скорости: %d\n"), modes[currentMode].Speed);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 2U: // удержание после двух кликов - изменение масштаба
|
||||||
|
{
|
||||||
|
modes[currentMode].Scale = constrain(brightDirection ? modes[currentMode].Scale + 1 : modes[currentMode].Scale - 1, 1, 100);
|
||||||
|
|
||||||
|
#ifdef GENERAL_DEBUG
|
||||||
|
LOG.printf_P(PSTR("Новое значение масштаба: %d\n"), modes[currentMode].Scale);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
settChanged = true;
|
||||||
|
eepromTimeout = millis();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// кнопка отпущена после удерживания
|
||||||
|
if (ONflag && !touch.isHold() && startButtonHolding) // кнопка отпущена после удерживания, нужно отправить MQTT сообщение об изменении яркости лампы
|
||||||
|
{
|
||||||
|
startButtonHolding = false;
|
||||||
|
loadingFlag = true;
|
||||||
|
|
||||||
#if (USE_MQTT)
|
#if (USE_MQTT)
|
||||||
if (espMode == 1U && ONflag && !touch.isHold() && startButtonHolding) // кнопка отпущена после удерживания, нужно отправить MQTT сообщение об изменении яркости лампы
|
if (espMode == 1U)
|
||||||
{
|
{
|
||||||
MqttManager::needToPublish = true;
|
MqttManager::needToPublish = true;
|
||||||
startButtonHolding = false;
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@@ -124,6 +124,10 @@ boolean GButton::isStep() {
|
|||||||
}
|
}
|
||||||
else return false;
|
else return false;
|
||||||
}
|
}
|
||||||
|
uint8_t GButton::getHoldClicks() {
|
||||||
|
if (flags.tickMode) GButton::tick();
|
||||||
|
return flags.hold_flag ? last_hold_counter : 0;
|
||||||
|
}
|
||||||
void GButton::tick(boolean state) {
|
void GButton::tick(boolean state) {
|
||||||
flags.mode = true;
|
flags.mode = true;
|
||||||
flags.btn_state = state ^ flags.inv_state;
|
flags.btn_state = state ^ flags.inv_state;
|
||||||
@@ -167,6 +171,7 @@ void GButton::tick() {
|
|||||||
// кнопка удерживается
|
// кнопка удерживается
|
||||||
if (flags.btn_flag && flags.btn_state && (millis() - btn_timer >= _timeout) && !flags.hold_flag) {
|
if (flags.btn_flag && flags.btn_state && (millis() - btn_timer >= _timeout) && !flags.hold_flag) {
|
||||||
flags.hold_flag = true;
|
flags.hold_flag = true;
|
||||||
|
last_hold_counter = btn_counter;
|
||||||
btn_counter = 0;
|
btn_counter = 0;
|
||||||
last_counter = 0;
|
last_counter = 0;
|
||||||
flags.isHolded_f = true;
|
flags.isHolded_f = true;
|
||||||
|
@@ -79,6 +79,7 @@ class GButton
|
|||||||
|
|
||||||
boolean hasClicks(); // проверка на наличие кликов. Сбрасывается после вызова
|
boolean hasClicks(); // проверка на наличие кликов. Сбрасывается после вызова
|
||||||
uint8_t getClicks(); // вернуть количество кликов
|
uint8_t getClicks(); // вернуть количество кликов
|
||||||
|
uint8_t getHoldClicks();// вернуть количество кликов, предшествующее удержанию кнопки (для шаблона управления "клик + удержание")
|
||||||
|
|
||||||
boolean isStep(); // возвращает true по таймеру setStepTimeout, смотри пример
|
boolean isStep(); // возвращает true по таймеру setStepTimeout, смотри пример
|
||||||
|
|
||||||
@@ -90,7 +91,7 @@ class GButton
|
|||||||
uint16_t _timeout = 0;
|
uint16_t _timeout = 0;
|
||||||
uint16_t _click_timeout = 0;
|
uint16_t _click_timeout = 0;
|
||||||
uint16_t _step_timeout = 0;
|
uint16_t _step_timeout = 0;
|
||||||
uint8_t btn_counter = 0, last_counter = 0;
|
uint8_t btn_counter = 0, last_counter = 0, last_hold_counter = 0;
|
||||||
uint32_t btn_timer = 0;
|
uint32_t btn_timer = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user