Debounce InterruptIn
Dependents: led_sigfox Allumag_lampe_sigfox Case_study_02_Turnstile B18_MP3_PLAYER ... more
Diff: DebouncedInterrupt.cpp
- Revision:
- 18:e6e9bc6402b7
- Parent:
- 17:96a51b236ba0
- Child:
- 19:d12a5b89ac3a
--- a/DebouncedInterrupt.cpp Tue Feb 18 20:38:50 2014 +0000 +++ b/DebouncedInterrupt.cpp Wed Feb 19 01:47:45 2014 +0000 @@ -17,15 +17,28 @@ delete _din; } -void DebouncedInterrupt::attach(void (*fptr)(void), const unsigned int& debounce_ms) +void DebouncedInterrupt::attach(void (*fptr)(void), const gpio_irq_event trigger, const unsigned int& debounce_ms) { if(fptr) { fCallback = fptr; _last_bounce_count = _bounce_count = 0; _debounce_us = 1000*debounce_ms; + _trigger = trigger; - _in->rise(this, &DebouncedInterrupt::_onInterrupt); - _in->fall(this, &DebouncedInterrupt::_onInterrupt); + switch(trigger) + { + case IRQ_RISE: + _in->rise(this, &DebouncedInterrupt::_onInterrupt); + break; + case IRQ_FALL: + _in->fall(this, &DebouncedInterrupt::_onInterrupt); + break; + case IRQ_NONE: + reset(); // Unexpected. Clear callbacks. + break; + } + } else { + reset(); } } @@ -43,7 +56,8 @@ { _last_bounce_count = _bounce_count; _bounce_count = 0; - if(_din->read()) { + unsigned int expected_state = (_trigger==IRQ_RISE)?1:0; + if(_din->read() == expected_state) { fCallback(); } }