diff options
author | uvok | 2025-07-17 21:33:50 +0200 |
---|---|---|
committer | uvok | 2025-07-17 21:33:50 +0200 |
commit | a5571a834f1b2b7ec0b8cdc016884442099ceab8 (patch) | |
tree | b6f1a2aa0ca3bc50957bcf7383f59fcca95fc4d4 /src | |
parent | 3f9e0e97aa0491d0143642f8302dd38afb42f479 (diff) |
Reorganize, scope, add GPIO
Diffstat (limited to 'src')
-rw-r--r-- | src/display.cpp | 4 | ||||
-rw-r--r-- | src/gpio.cpp | 35 | ||||
-rw-r--r-- | src/main.cpp | 26 |
3 files changed, 41 insertions, 24 deletions
diff --git a/src/display.cpp b/src/display.cpp index cde438f..54da2db 100644 --- a/src/display.cpp +++ b/src/display.cpp @@ -1,11 +1,11 @@ -#include "display.h" +#include "badge/display.h" #include <Fonts/FreeMonoBold18pt7b.h> #include <Fonts/FreeMonoBold9pt7b.h> // #include <GxEPD2_3C.h> #include <GxEPD2_BW.h> -#include "badge_config.h" +#include "badge/config.h" #if UVOK_EPAP_DISPLAY == DISPLAY_WAVESHARE_219_YBW // HINT: Update the library code, set budy timeout to 30 or 60 seconds! diff --git a/src/gpio.cpp b/src/gpio.cpp new file mode 100644 index 0000000..d7dcd7b --- /dev/null +++ b/src/gpio.cpp @@ -0,0 +1,35 @@ +#include "badge/gpio.h" + +#include <Arduino.h> + +#define BUTTON_PIN 0 + +static unsigned long pressedTime = 0; +static unsigned long releasedTime = 0; + +void de::uvok::badge::gpio_init(void) +{ +} + +long de::uvok::badge::gpio_poll(void) +{ + static int lastState = HIGH; + int buttonState = digitalRead(BUTTON_PIN); + long pressDuration = 0; + if (lastState == HIGH && buttonState == LOW) + { + Serial.println("``\\__"); + pressedTime = millis(); + lastState = LOW; + } + else if (lastState == LOW && buttonState == HIGH) + { + lastState = HIGH; + Serial.println("__/``"); + releasedTime = millis(); + + pressDuration = releasedTime - pressedTime; + }; + + return pressDuration; +} diff --git a/src/main.cpp b/src/main.cpp index dbb929b..4ac8465 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -7,8 +7,9 @@ #include <HTTPUpdateServer.h> #include <WebServer.h> -#include "badge_config.h" -#include "display.h" +#include "badge/config.h" +#include "badge/display.h" +#include "badge/gpio.h" #if defined(BADGE_SSID_NAME) && defined(BADGE_SSID_PASS) #define BADGE_USE_WIFI 1 @@ -18,9 +19,6 @@ NimBLEServer *server; -unsigned long pressedTime = 0; -unsigned long releasedTime = 0; -#define BUTTON_PIN 0 #define PRESS_TIME_DRAW 1000 #define PRESS_TIME_BLE_ADV 3000 #define SLEEP_TIME 10000 @@ -70,23 +68,7 @@ void loop() httpServer.handleClient(); #endif - static int lastState = HIGH; - int buttonState = digitalRead(BUTTON_PIN); - long pressDuration = 0; - if (lastState == HIGH && buttonState == LOW) - { - Serial.println("``\\__"); - pressedTime = millis(); - lastState = LOW; - } - else if (lastState == LOW && buttonState == HIGH) - { - lastState = HIGH; - Serial.println("__/``"); - releasedTime = millis(); - - pressDuration = releasedTime - pressedTime; - }; + uint16_t pressDuration = de::uvok::badge::gpio_poll(); if (pressDuration > PRESS_TIME_BLE_ADV) { if (!pAdvertising->isAdvertising()) |