refactor(touch): centralize touch handling in DoorbellLogic

This commit is contained in:
2026-02-17 23:35:59 -08:00
parent 4f389ac0fe
commit 46289b9d40
6 changed files with 91 additions and 53 deletions

View File

@@ -21,18 +21,12 @@ void setup() {
} }
void loop() { void loop() {
// ── Touch debug: poll continuously ── // ── Read touch ──
TouchEvent evt = display.readTouch(); TouchEvent evt = display.readTouch();
// ── Touch debug ──
if(evt.pressed) { if(evt.pressed) {
Serial.printf("[TOUCH] pressed: x=%d, y=%d\n", evt.x, evt.y); Serial.printf("[TOUCH] pressed: x=%d, y=%d\n", evt.x, evt.y);
} else {
// Debug: print raw Z even when not touched, to see controller state
static uint32_t lastDebug = 0;
if(millis() - lastDebug > 2000) {
lastDebug = millis();
uint16_t z = tftDriver.getRawTouchZ();
Serial.printf("[TOUCH] Raw Z=%d\n", z);
}
} }
// ── State machine tick ── // ── State machine tick ──
@@ -41,8 +35,11 @@ void loop() {
// ── Render current screen ── // ── Render current screen ──
display.render(logic.getScreenState()); display.render(logic.getScreenState());
// ── Touch handling ── // ── Touch handling (tap gestures) ──
const ScreenState& st = logic.getScreenState(); const ScreenState& st = logic.getScreenState();
int tile = logic.handleTouch(evt);
// ── Hold gesture (for silencing alerts) ──
static int holdStartX = -1; static int holdStartX = -1;
static int holdStartY = -1; static int holdStartY = -1;
@@ -54,9 +51,8 @@ void loop() {
holdStartY = -1; holdStartY = -1;
} }
if(h.started) { if(h.started) {
TouchEvent t = display.readTouch(); holdStartX = evt.x;
holdStartX = t.x; holdStartY = evt.y;
holdStartY = t.y;
} }
if(holdStartX >= 0) { if(holdStartX >= 0) {
display.updateHint(holdStartX, holdStartY, h.active); display.updateHint(holdStartX, holdStartY, h.active);
@@ -66,15 +62,6 @@ void loop() {
holdStartY = -1; holdStartY = -1;
} }
if(st.screen == ScreenID::DASHBOARD) {
TouchEvent evt = display.readTouch();
if(evt.pressed) {
int tile = display.dashboardTouch(evt.x, evt.y);
if(tile >= 0)
Serial.printf("[DASH] Tile %d tapped\n", tile);
}
}
// ── Serial console ── // ── Serial console ──
if(Serial.available()) { if(Serial.available()) {
String cmd = Serial.readStringUntil('\n'); String cmd = Serial.readStringUntil('\n');

View File

@@ -21,14 +21,20 @@ void setup() {
} }
void loop() { void loop() {
// ── Read touch ──
TouchEvent evt = display.readTouch();
// ── State machine tick ── // ── State machine tick ──
logic.update(); logic.update();
// ── Render current screen ── // ── Render current screen ──
display.render(logic.getScreenState()); display.render(logic.getScreenState());
// ── Touch handling ── // ── Touch handling (tap gestures) ──
const ScreenState& st = logic.getScreenState(); const ScreenState& st = logic.getScreenState();
int tile = logic.handleTouch(evt);
// ── Hold gesture (for silencing alerts) ──
static int holdStartX = -1; static int holdStartX = -1;
static int holdStartY = -1; static int holdStartY = -1;
@@ -40,11 +46,9 @@ void loop() {
holdStartY = -1; holdStartY = -1;
} }
if(h.started) { if(h.started) {
TouchEvent t = display.readTouch(); holdStartX = evt.x;
holdStartX = t.x; holdStartY = evt.y;
holdStartY = t.y;
} }
// Fix for esp32-32e.ino
if(holdStartX >= 0) { if(holdStartX >= 0) {
display.updateHint(holdStartX, holdStartY, h.active); display.updateHint(holdStartX, holdStartY, h.active);
} }
@@ -53,15 +57,6 @@ void loop() {
holdStartY = -1; holdStartY = -1;
} }
if(st.screen == ScreenID::DASHBOARD) {
TouchEvent evt = display.readTouch();
if(evt.pressed) {
int tile = display.dashboardTouch(evt.x, evt.y);
if(tile >= 0)
Serial.printf("[DASH] Tile %d tapped\n", tile);
}
}
// ── Serial console ── // ── Serial console ──
if(Serial.available()) { if(Serial.available()) {
String cmd = Serial.readStringUntil('\n'); String cmd = Serial.readStringUntil('\n');

View File

@@ -21,14 +21,18 @@ void setup() {
} }
void loop() { void loop() {
// ── Read touch ──
TouchEvent evt = display.readTouch(); TouchEvent evt = display.readTouch();
// ── State machine tick ──
logic.update(); logic.update();
display.render(logic.getScreenState()); display.render(logic.getScreenState());
// ── Touch handling (tap gestures) ──
const ScreenState& st = logic.getScreenState(); const ScreenState& st = logic.getScreenState();
int tile = logic.handleTouch(evt);
// Track initial hold position for hint // ── Hold gesture (for silencing alerts) ──
static int holdStartX = -1; static int holdStartX = -1;
static int holdStartY = -1; static int holdStartY = -1;
@@ -43,7 +47,6 @@ void loop() {
holdStartX = evt.x; holdStartX = evt.x;
holdStartY = evt.y; holdStartY = evt.y;
} }
// Draw hint during hold (ACTIVE) or idle (IDLE)
if(holdStartX >= 0) { if(holdStartX >= 0) {
if(h.active) { if(h.active) {
display.updateHint(holdStartX, holdStartY, true); display.updateHint(holdStartX, holdStartY, true);
@@ -55,21 +58,6 @@ void loop() {
holdStartX = -1; holdStartX = -1;
holdStartY = -1; holdStartY = -1;
} }
if(evt.pressed) {
if(st.screen == ScreenID::OFF) {
// Tap in OFF mode → wake to DASHBOARD
Serial.println("[TOUCH] OFF → DASHBOARD");
logic.setScreen(ScreenID::DASHBOARD);
display.setBacklight(true);
} else if(st.screen == ScreenID::DASHBOARD) {
int tile = display.dashboardTouch(evt.x, evt.y);
if(tile >= 0) {
Serial.printf("[DASH] Tile %d tapped\n", tile);
}
} else if(st.screen == ScreenID::ALERT) {
Serial.println("[TOUCH] ALERT tap");
}
}
if(Serial.available()) { if(Serial.available()) {
String cmd = Serial.readStringUntil('\n'); String cmd = Serial.readStringUntil('\n');

View File

@@ -278,3 +278,29 @@ void DoorbellLogic::setScreen(ScreenID s) {
_display->setBacklight(needsBacklight); _display->setBacklight(needsBacklight);
_state.backlightOn = needsBacklight; _state.backlightOn = needsBacklight;
} }
int DoorbellLogic::handleTouch(const TouchEvent& evt) {
if(!evt.pressed)
return -1;
if(_state.screen == ScreenID::OFF) {
Serial.println("[TOUCH] OFF → DASHBOARD");
setScreen(ScreenID::DASHBOARD);
return -1;
}
if(_state.screen == ScreenID::DASHBOARD) {
int tile = _display->dashboardTouch(evt.x, evt.y);
if(tile >= 0) {
Serial.printf("[DASH] Tile %d tapped\n", tile);
}
return tile;
}
if(_state.screen == ScreenID::ALERT) {
Serial.println("[TOUCH] ALERT tap");
return -1;
}
return -1;
}

View File

@@ -25,6 +25,8 @@ public:
/// Externally trigger silence (e.g. hold-to-silence gesture). /// Externally trigger silence (e.g. hold-to-silence gesture).
void silenceAlert(); void silenceAlert();
void setScreen(ScreenID s); void setScreen(ScreenID s);
/// Handle touch input — returns dashboard tile index if tapped, or -1.
int handleTouch(const TouchEvent& evt);
private: private:
void pollTopics(); void pollTopics();

View File

@@ -2,6 +2,46 @@
# Klubhaus Doorbell — Multi-Target Build Harness # Klubhaus Doorbell — Multi-Target Build Harness
# ═══════════════════════════════════════════════════════════ # ═══════════════════════════════════════════════════════════
# Usage:
# BOARD=esp32-32e-4 mise run compile # compile for esp32-32e-4
# BOARD=esp32-32e-4 mise run upload # upload to esp32-32e-4
# BOARD=esp32-32e-4 mise run monitor # monitor esp32-32e-4
#
# Valid BOARD values: esp32-32e, esp32-32e-4, esp32-s3-43
[tasks.compile]
description = "Compile (uses BOARD env var)"
run = """
case "$BOARD" in
esp32-32e) mise run compile-32e ;;
esp32-32e-4) mise run compile-32e-4 ;;
esp32-s3-43) mise run compile-s3-43 ;;
*) echo "Unknown BOARD: $BOARD" && exit 1 ;;
esac
"""
[tasks.upload]
description = "Upload (uses BOARD env var)"
run = """
case "$BOARD" in
esp32-32e) mise run upload-32e ;;
esp32-32e-4) mise run upload-32e-4 ;;
esp32-s3-43) mise run upload-s3-43 ;;
*) echo "Unknown BOARD: $BOARD" && exit 1 ;;
esac
"""
[tasks.monitor]
description = "Monitor (uses BOARD env var)"
run = """
case "$BOARD" in
esp32-32e) mise run monitor-32e ;;
esp32-32e-4) mise run monitor-32e-4 ;;
esp32-s3-43) mise run monitor-s3-43 ;;
*) echo "Unknown BOARD: $BOARD" && exit 1 ;;
esac
"""
[tasks.install-libs-shared] [tasks.install-libs-shared]
description = "Install shared (platform-independent) libraries" description = "Install shared (platform-independent) libraries"
run = """ run = """