Skip to content

Latest commit

 

History

History
96 lines (68 loc) · 2.7 KB

README.md

File metadata and controls

96 lines (68 loc) · 2.7 KB

Onixarts_IO

Input and output helper library for Arduino, simplify common IO tasks implementation. This library is used by Hapcanuino project.

Library dependencies

Features

Digital Output

  • On, Off, Toggle, Blink functions
  • Configurable active level (LOW, HIGH)
  • Every function execution can be Delayed
  • No timer used (using millis())
  • Not suitable for high time precision tasks

Digital Input (button)

  • Input debouncing (20ms default)
  • 9 events for button (pressed, released, released before 400ms, held for 400ms, released after 400ms, held for 1s, released after 1s, held for 4s, released after 4s)
  • Non-blocking time measure and debouncing
  • No timer used (using millis())
  • Configurable active input level (LOW, HIGH)
  • Configurable built-in pull-up resistor usage

Basic usage

DigitalOutput

See HelloWorld_DigitalOutput example for full code.

Include main library and dependecies:

#include <OnixartsIO.h>
#include <OnixartsTaskManager.h>

Library used namespaces to organize types and consts, so put a default namespace and declare LED obect as built in diode.

using namespace Onixarts::Tools;

IO::DigitalOutput led(LED_BUILTIN, true);
//IO::DigitalOutput led(LED_BUILTIN);

First constructor parameter is the output PIN, second is active level. True is de default value and it can be ignored. It means that active level is HIGH. Passing false will cause set active level to LOW value on output pin.

In setup() call Init() method which will setup pin mode.

void setup()
{
	Serial.begin(115200);
	Serial.println("Onixarts IO Digital Output demo");

	led.Init();
}

In loop() function You should call Update() method, which will handle delay and blink tasks. This method do not block program execution and should be call as often as possible. Do not put Arduino delay() function in loop() because it will affect delay and blink accuracy.

void loop()
{
	led.Update();
}

Now You can use digitalOutput like shown below:

	// switch output to active level
	led.On();

	// switch off after 5s
	led.Off(5000);

	// toggle led after 3s
	led.Toggle(3000);

	// blink led 10 times with 50ms duration after 5s
	led.Blink(50, 10, 5000);

	// change default active level to LOW, normally used once in setup to match board configuration 
	led.SetOutputActiveLevel(false);

	// On function cause LOW level on output pin
	led.On();

	// Off cause HIGH level on output pin
	led.Off(5000);