From: Christian Pointner Date: Sun, 26 Apr 2009 23:28:43 +0000 (+0000) Subject: added debouncing to manual keys X-Git-Url: https://git.realraum.at/?a=commitdiff_plain;h=082cf658c276a87e89c0f427683371c7a85ac349;p=svn42.git added debouncing to manual keys --- diff --git a/firmware/tuer.pde b/firmware/tuer.pde index 1808c88..c0c4bf1 100644 --- a/firmware/tuer.pde +++ b/firmware/tuer.pde @@ -22,6 +22,13 @@ byte next_led = 0; #define MANUAL_OPEN_PIN 12 // keys for manual open and close #define MANUAL_CLOSE_PIN 13 // +#define DEBOUNCE_DELAY 625 // * 16us = 10ms +#define DEBOUNCE_IDLE 0 // currently no debouncing +#define DEBOUNCE_OPEN 1 // debouncing open key +#define DEBOUNCE_CLOSE 2 // debouncing close key +#define DEBOUNCE_FINISHED 4 // debouncing finished +byte debounce_state; +int debounce_cnt = 0; #define IDLE 0 // close and open may be called #define OPENING 1 // opening, only 's' command is allowed @@ -76,9 +83,12 @@ void init_manual() pinMode(MANUAL_CLOSE_PIN, INPUT); // set pin to input digitalWrite(MANUAL_CLOSE_PIN, HIGH); // turn on pullup resistors + + debounce_state = DEBOUNCE_IDLE; + debounce_cnt = DEBOUNCE_DELAY; } -boolean manual_open() +boolean manual_open_pressed() { if(digitalRead(MANUAL_OPEN_PIN)) return false; @@ -86,7 +96,7 @@ boolean manual_open() return true; } -boolean manual_close() +boolean manual_close_pressed() { if(digitalRead(MANUAL_CLOSE_PIN)) return false; @@ -94,6 +104,92 @@ boolean manual_close() return true; } +void start_debounce_timer() // this breaks millis() function, but who cares +{ + debounce_cnt = DEBOUNCE_DELAY; + + TCCR0A = 0; // no prescaler, WGM = 0 (normal) + TCCR0B = 1< 16us @ 16 MHz + TCNT0 = 0; // reseting timer + TIMSK0 = 1<