GithubHelp home page GithubHelp logo

rzolotuhin / arduino-cron Goto Github PK

View Code? Open in Web Editor NEW
0.0 1.0 1.0 10 KB

This library allows you to implement the call of user-defined functions at a certain time interval. The mechanism is similar to СRON in Linux

C++ 100.00%

arduino-cron's Introduction

arduino cron

Эта библиотека позволяет реализовать вызов пользовательских функций через определенный промежуток времени. Механизм аналогичен СRON в Linux.

Список доступных методов

Пользовательские объекты

Описание методов


cron.add

Добавление нового задания в планировщик

bool add(uint32_t interval, cronEvent::userFunction_t function[, bool start, const char* name])
  • interval - интервал вызова пользовательской функции в ms или используйте специальные константы
  • function - имя пользовательской функции которую необходимо вызвать (не должна принимать параметры и возвращать значение)
  • start - (не обязательно) если установлено true, то пользовательская функция будет вызвана первый раз при добавлении в планировщик
  • name - (не обязательно) читаемое имя задания по которому можно его найти и изменить

Возвращает true или false, в зависимости от успеха добавления нового задания

cron.add(cron::second, user_function_name);
cron.add(cron::second, [](){
  ...
});
if (cron.add(1000, user_function_name)) {
  Serial.println('added user function in cron');
}

cron.handleEvents

Обработчик очереди заданий

void handleEvents()

Добавляется в функцию loop и занимается запуском заданий

void loop() {
  cron.handleEvents();
}

cron.find

Поиск задания по имени

iterator_t cron.find(const char* name);

Возвращает объект задания (Class::cronEvent) или итератор end (std::list) в случае неудачи

if (cron.find("Blink")) {
  cron.update("Blink", 250);
}

cron.lastRun

Возвращает количество ms прошедших с момента последнего вызова задания. Если параметр идентифицирующий задание не задан, то вернет значение, относящееся к последнему добавленному заданию в список.

uint32_t lastRun()
uint32_t lastRun(cronEvent &item)
uint32_t lastRun(const char* name)
uint32_t lastRun(iterator_t item)

Если задание не найдено, то возвращает 0

Serial.println(cron.lastRun("Blink"));
iterator_t item = cron.find("Blink");
if (item) {
  uint32_t time = cron.lastRun(item);
  Serial.println(time);
}

cron.update

Обновление таймера задания.

void update(const char* name[, uint32_t interval])
  • name - имя задания
  • interval - (не обязательно) новый интервал времени для запуска задания Обновит таймер запуска задания без вызова пользовательской функции, это отсрочит время запуска пользовательской функции на интервал времени заданный для этого задания. Если задан не обязательный параметр interval, то также будет изменен интервал запуска задания.
cron.add(cron::time_1s, [](){ Serial.println("+1 blink"); }, "Blink");
cron.update("Blink", cron::time_5s);

cron.stop

Остановка выполнения задания.

void stop(const char* name)

После вызова устанавливает интервал запуска для задания в 0, что приведет к полной остановке выполнения этого задания.

cron.stop("Blink");

cron.isActive

Проверяет активна задача или нет

bool isActive(const char* name)

Возвращает true в случае если задание выполняется, в противном случае вернет false

cron.size

Возвращает размер очереди заданий

size_t size()

cron.last

Возвращает последнее задание в очереди

cronEvent &last()

Пользовательские объекты


cronEvent::userFunction_t

Описывает тип пользовательской функции принимаемой в качестве аргумента для метода add.

typedef std::function<void(void)> userFunction_t;

Данная конструкция описывает, что пользователь должен создать функцию, которая не принимает никакие параметры и ничего не возвращает. Ей будут доступны все глобальные объекты и переменные объявленные ранее.

Примеры использования


Задание на изменение состояния светодиода

#include <cron.h>

#define ledPin 2 // NodeMCU & ESP 12

void setup() {
  pinMode(ledPin, OUTPUT);

  cron.add(cron::second, blink_f);
}

void loop() {
  cron.handleEvents();
}

void blink_f() {
  digitalWrite(ledPin, !digitalRead(ledPin));
}

Прмиер взаимодействия нескольких заданий и изменение их свойств

#include <cron.h>

#define ledPin 2 // NodeMCU & ESP 12

void setup() {
  Serial.begin(115200);
  Serial.println();

  pinMode(ledPin, OUTPUT);

  /* Main task */
  cron.add(cron::second, blink_f, "Blink");
  /* Control task */
  cron.add(cron::time_5s, control_f);
  /* Changing the state for the task "Blink" */
  cron.add(cron::time_10s, switch_f);
}

void loop() {
  cron.handleEvents();
}

void blink_f() {
  digitalWrite(ledPin, !digitalRead(ledPin));
}

void control_f() {
  if (cron.isActive("Blink")) {
    Serial.println(F("Task \"Blink\" is active"));
  } else {
    Serial.println(F("Task \"Blink\" is not active"));
  }
}

void switch_f() {
  if (cron.isActive("Blink")) {
    cron.stop("Blink");
    Serial.println(F("The task is stopped"));
  } else {
    cron.update("Blink", cron::time_1s); // You can set any interval
    Serial.println(F("The task is resumed"));
  }
}

arduino-cron's People

Contributors

rzolotuhin avatar

Watchers

 avatar

Forkers

kleyton67

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.