Многофункциональный программный таймер на системном таймере millis() для Arduino
- Режим таймера и периодичного выполнения
- Подключение функции-обработчика
- Сброс/запуск/перезапуск/остановка/пауза/продолжение отсчёта
- Возможность форсировать переполнение таймера
- Возврат оставшегося времени в мс, а также условных единицах 8 и 16 бит
- Несколько функций получения текущего статуса таймера
- Алгоритм держит стабильный период и не боится переполнения millis()
Совместима со всеми Arduino платформами (используются Arduino-функции)
- Библиотеку можно найти по названию TimerMs и установить через менеджер библиотек в:
- Arduino IDE
- Arduino IDE v2
- PlatformIO
- Скачать библиотеку .zip архивом для ручной установки:
- Распаковать и положить в C:\Program Files (x86)\Arduino\libraries (Windows x64)
- Распаковать и положить в C:\Program Files\Arduino\libraries (Windows x32)
- Распаковать и положить в Документы/Arduino/libraries/
- (Arduino IDE) автоматическая установка из .zip: Скетч/Подключить библиотеку/Добавить .ZIP библиотеку… и указать скачанный архив
- Читай более подробную инструкцию по установке библиотек здесь
- Рекомендую всегда обновлять библиотеку: в новых версиях исправляются ошибки и баги, а также проводится оптимизация и добавляются новые фичи
- Через менеджер библиотек IDE: найти библиотеку как при установке и нажать "Обновить"
- Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!
// (период, мс), (0 не запущен / 1 запущен), (режим: 0 период / 1 таймер)
TimerMs tmr; // время 1000мс, не запущен, режим периода
TimerMs tmr(uint32_t prd); // время prd, не запущен, режим периода
TimerMs tmr(uint32_t prd, bool state); // время prd, state статус, режим периода
TimerMs tmr(uint32_t prd, bool state, bool mode); // время prd, state статус, mode: 0 период / 1 таймер
void setMicros(bool mode); // включить микросекундный режим (true)
void setTimerMode(); // установить в режим таймера (остановится после срабатывания)
void setPeriodMode(); // установить в режим периода (перезапустится после срабатывания)
void setTime(uint32_t prd); // установить время
void attach(void (*handler)()); // подключить коллбэк
void detach(); // отключить коллбэк
void start(); // запустить/перезапустить таймер
void resume(); // продолжить после остановки
void stop(); // остановить/приостановить таймер
void force(); // принудительно переполнить таймер
// в режиме периода однократно вернёт true при каждом периоде
// в режиме таймера будет возвращать true при срабатывании
bool tick();
bool ready(); // однократно вернёт true при срабатывании (флаг)
bool elapsed(); // всегда возвращает true при срабатывании
bool active(); // работает ли таймер (start/resume)
bool status(); // elapsed+active: работает ли таймер + не сработал ли он
uint32_t timeLeft(); // остаток времени в мс
uint8_t timeLeft8(); // остаток времени в 0-255
uint16_t timeLeft16(); // остаток времени в 0-65535
#include <TimerMs.h>
// (период, мс), (0 не запущен / 1 запущен), (режим: 0 период / 1 таймер)
TimerMs tmr(2000, 1, 1);
void setup() {
Serial.begin(9600);
//tmr.setTimerMode();
tmr.setPeriodMode();
}
void loop() {
if (tmr.tick()) Serial.println("finish");
}
- v1.0
- v1.1 - добавил микросекундный режим
- v1.1.1 - небольшой фикс
- v1.2 - фикс функции stop
При нахождении багов создавайте Issue, а лучше сразу пишите на почту alex@alexgyver.ru
Библиотека открыта для доработки и ваших Pull Request'ов!
При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать:
- Версия библиотеки
- Какой используется МК
- Версия SDK (для ESP)
- Версия Arduino IDE
- Корректно ли работают ли встроенные примеры, в которых используются функции и конструкции, приводящие к багу в вашем коде
- Какой код загружался, какая работа от него ожидалась и как он работает в реальности
- В идеале приложить минимальный код, в котором наблюдается баг. Не полотно из тысячи строк, а минимальный код