summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authoruvok2025-07-17 21:33:50 +0200
committeruvok2025-07-17 21:33:50 +0200
commita5571a834f1b2b7ec0b8cdc016884442099ceab8 (patch)
treeb6f1a2aa0ca3bc50957bcf7383f59fcca95fc4d4 /src
parent3f9e0e97aa0491d0143642f8302dd38afb42f479 (diff)
Reorganize, scope, add GPIO
Diffstat (limited to 'src')
-rw-r--r--src/display.cpp4
-rw-r--r--src/gpio.cpp35
-rw-r--r--src/main.cpp26
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())