refactor(touch): centralize touch handling in DoorbellLogic
This commit is contained in:
@@ -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');
|
||||||
|
|||||||
@@ -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');
|
||||||
|
|||||||
@@ -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');
|
||||||
|
|||||||
@@ -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;
|
||||||
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
40
mise.toml
40
mise.toml
@@ -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 = """
|
||||||
|
|||||||
Reference in New Issue
Block a user