Compare commits
No commits in common. "a343d97e3df17f093087d880cdf021b60f6b0bf3" and "bf3e269eee0e99ea4733605f1551d07366b978f7" have entirely different histories.
a343d97e3d
...
bf3e269eee
@ -1,10 +1,7 @@
|
|||||||
# Intrval - Arduino knihovna pro časování pomocí intervalů
|
# Interval
|
||||||
|
Arduino knihovna pro časování pomocí intervalů
|
||||||
Koncepce programové konstrukce aplikace pro Arduino spočívá ve dvou hlavních metodách – **setup()** a **loop()**, ve které program neustále běží.
|
Koncepce programové konstrukce aplikace pro Arduino spočívá ve dvou hlavních metodách – **setup()** a **loop()**, ve které program neustále běží.
|
||||||
Pro pohodlnější práci s obsluhou periodických procesů jsem napsal jednoduchou knihovnu, která tyto úkoly umožňuje napsat velmi elegantním způsobem.
|
Pro pohodlnější práci s obsluhou periodických procesů jsem napsal jednoduchou knihovnu, která tyto úkoly umožňuje napsat velmi elegantním způsobem.
|
||||||
|
|
||||||
Knihovna **Interval** vytváří časovací objekty a zpřístupňuje dvě metody – metodu **set** a metodu **expired**.
|
Knihovna **Interval** vytváří časovací objekty a zpřístupňuje dvě metody – metodu **set** a metodu **expired**.
|
||||||
|
|
||||||
Metoda **set** se používá k nastavení timeoutu a definici začátku časování, metoda **expired** pak slouží k ověření, zda nastavený interval již vypršel.
|
Metoda **set** se používá k nastavení timeoutu a definici začátku časování, metoda **expired** pak slouží k ověření, zda nastavený interval již vypršel.
|
||||||
|
|
||||||
Zajímavostí je, že knihovna korektně ošetřuje přetečení vnitřního milisekundového čítače, takže nehrozí nebezpečí špatného časování i při velmi dlouhé době chodu zařízení.
|
Zajímavostí je, že knihovna korektně ošetřuje přetečení vnitřního milisekundového čítače, takže nehrozí nebezpečí špatného časování i při velmi dlouhé době chodu zařízení.
|
||||||
|
@ -10,9 +10,9 @@
|
|||||||
"repository":
|
"repository":
|
||||||
{
|
{
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "http://git.xpablo.cz/pablo2048/Interval.git"
|
"url": "https://github.com/Pablo2048/Interval.git"
|
||||||
},
|
},
|
||||||
"version": "0.0.3",
|
"version": "0.0.2",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"frameworks": "arduino",
|
"frameworks": "arduino",
|
||||||
"platforms": "*",
|
"platforms": "*",
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
name=Interval
|
name=Interval
|
||||||
version=0.0.3
|
version=0.0.2
|
||||||
author=Pavel Brychta
|
author=Pavel Brychta
|
||||||
maintainer=Pavel Brychta
|
maintainer=Pavel Brychta
|
||||||
sentence=Make timing by using intervals instead of delay()
|
sentence=Make timing by using intervals instead of delay()
|
||||||
|
@ -21,64 +21,24 @@ uint32_t Interval::elapsed(void)
|
|||||||
|
|
||||||
bool Interval::expired(void)
|
bool Interval::expired(void)
|
||||||
{
|
{
|
||||||
bool result = false;
|
|
||||||
if (_done)
|
|
||||||
{
|
|
||||||
if (1 == _mode)
|
|
||||||
{ // oneshot mode
|
|
||||||
if ((millis() - _timefrom) >= _timeout)
|
if ((millis() - _timefrom) >= _timeout)
|
||||||
{
|
return true;
|
||||||
_done = 0;
|
|
||||||
result = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (2 == _mode)
|
|
||||||
{ // periodic mode
|
|
||||||
if ((millis() - _timefrom) >= _timeout)
|
|
||||||
{
|
|
||||||
result = true;
|
|
||||||
_timefrom = millis();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{ // compatibility mode
|
return false;
|
||||||
if ((millis() - _timefrom) >= _timeout)
|
|
||||||
result = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Interval::set(uint32_t tmout)
|
void Interval::set(uint32_t tmout)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
_reload = tmout;
|
||||||
_timefrom = millis();
|
_timefrom = millis();
|
||||||
_timeout = tmout;
|
_timeout = _reload;
|
||||||
_mode = 0;
|
|
||||||
_done = 0xff;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Interval::setOneshot(uint32_t tmout)
|
|
||||||
{
|
|
||||||
|
|
||||||
_timefrom = millis();
|
|
||||||
_timeout = tmout;
|
|
||||||
_mode = 1;
|
|
||||||
_done = 0xff;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Interval::setPeriodic(uint32_t tmout)
|
|
||||||
{
|
|
||||||
|
|
||||||
_timefrom = millis();
|
|
||||||
_timeout = tmout;
|
|
||||||
_mode = 2;
|
|
||||||
_done = 0xff;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Interval::reload(void)
|
void Interval::reload(void)
|
||||||
{
|
{
|
||||||
|
|
||||||
_timefrom = millis();
|
_timefrom = millis();
|
||||||
_done = 0xff;
|
_timeout = _reload;
|
||||||
}
|
}
|
||||||
|
@ -15,14 +15,10 @@ class Interval
|
|||||||
protected:
|
protected:
|
||||||
uint32_t _timefrom;
|
uint32_t _timefrom;
|
||||||
uint32_t _timeout;
|
uint32_t _timeout;
|
||||||
uint8_t _mode; // mode of actual operation (compatibility, oneshot, periodic)
|
uint32_t _reload;
|
||||||
uint8_t _done;
|
|
||||||
public:
|
public:
|
||||||
Interval(): _mode(0), _done(0xff) {}
|
|
||||||
bool expired(void);
|
bool expired(void);
|
||||||
void set(uint32_t tmout);
|
void set(uint32_t tmout);
|
||||||
void setOneshot(uint32_t tmout);
|
|
||||||
void setPeriodic(uint32_t tmout);
|
|
||||||
void reload(void);
|
void reload(void);
|
||||||
uint32_t elapsed(void);
|
uint32_t elapsed(void);
|
||||||
uint32_t remains(void);
|
uint32_t remains(void);
|
||||||
|
Loading…
Reference in New Issue
Block a user