vote controller

Dependencies:   MQTT

Fork of PGO6_VoteController_template by Jens de hoog

debounce_button.cpp

Committer:
niels_balemans
Date:
2018-10-11
Revision:
4:836cd4df41ba
Parent:
3:062b94b59b1b

File content as of revision 4:836cd4df41ba:

#include "debounce_button.h"

/**
    Some tips and tricks:
    -   To use the built-in LED:
            DigitalOut led1(LED1);
            ...
            led1 = 1;
    -   To delay the call of a function:
            Timeout someTimeout;
            ...
            someTimeout.attach(callback(&someFunction), 0.5) with 0.5 as 500 milliseconds
    -   The variables that are used in interrupt callbacks have to be volatile, 
        because these variables can change at any time. Therefore, the compiler is not 
        going to make optimisations.
*/

volatile bool button1_pressed = false;
volatile bool button1_enabled = true;
volatile bool button1_busy = false; 
volatile int multiclick_state = 0;
int counter = 0;
DigitalOut myled(LED1);
Timeout debouncer_delay;
Timeout busy_delay;
DigitalOut led2(LED2);

void showPresses() {
    for(int i = 0; i < multiclick_state; i++) {
        led2 = 1;
        wait(1);
        led2 = 0;
        wait(1);
    }
}

/**
    TODO
    ----
    This function:
        -   stores the amount of clicks in a variable which is read by the main loop.
        -   resets the click counter which is used inside this file.
        -   lowers a flag which tells the main loop that the user stopped pressing the button
            such that it can proceed its program.
        -   turns the built-in LED off. Therefore, the user gets informed that the program stopped counting the clicks.
*/
void button1_multiclick_reset_cb(void) {
    multiclick_state = counter;
    counter = 0;
    button1_busy = false;
    myled = 0;
    //showPresses();
}

/**
    TODO
    ----
    This function enables the button again, such that unwanted clicks of the bouncing button get ignored.
*/
void button1_enabled_cb(void) {
    button1_enabled = true;
}

/**
    TODO
    ----
    This function:
        -   turns the built-in LED on, so the user gets informed that the program has started with counting clicks
        -   disables the button such that the debouncer is active
        -   enables the button again after a certain amount of time 
            (use interrupts with "button1_enabled_cb()" as callback.
        -   counts the amount of clicks within a period of 1 second
        -   informs the main loop that the button has been pressed
        -   informs the main loop that the user is clicking the button.
            Therefore, this main loop cannot continue its procedure until the clicks within 1 second have been counted.
*/
void button1_onpressed_cb(void)
{
    if (button1_enabled) { // Disabled while the button is bouncing
        button1_enabled = false;
        button1_pressed = true; // To be read by the main loop
        debouncer_delay.attach(callback(button1_enabled_cb), 0.05); // Debounce time 50 ms
        counter++;
        if(!button1_busy) {
            myled = 1;
            button1_busy = true;
            busy_delay.attach(callback(button1_multiclick_reset_cb), 1);
        }
    }
}