style: apply consistent code formatting and spacing
This commit is contained in:
@@ -1,8 +1,9 @@
|
||||
#pragma once
|
||||
|
||||
#include "board_config.h"
|
||||
|
||||
#include <KlubhausCore.h>
|
||||
#include <TFT_eSPI.h>
|
||||
#include "board_config.h"
|
||||
|
||||
class DisplayDriverTFT : public IDisplayDriver {
|
||||
public:
|
||||
@@ -10,11 +11,11 @@ public:
|
||||
void setBacklight(bool on) override;
|
||||
void render(const ScreenState& state) override;
|
||||
TouchEvent readTouch() override;
|
||||
int dashboardTouch(int x, int y) override;
|
||||
int dashboardTouch(int x, int y) override;
|
||||
HoldState updateHold(unsigned long holdMs) override;
|
||||
void updateHint(int x, int y) override;
|
||||
int width() override { return DISPLAY_WIDTH; }
|
||||
int height() override { return DISPLAY_HEIGHT; }
|
||||
int width() override { return DISPLAY_WIDTH; }
|
||||
int height() override { return DISPLAY_HEIGHT; }
|
||||
|
||||
private:
|
||||
void drawBoot();
|
||||
@@ -23,8 +24,8 @@ private:
|
||||
|
||||
TFT_eSPI _tft;
|
||||
|
||||
bool _holdActive = false;
|
||||
bool _holdActive = false;
|
||||
uint32_t _holdStartMs = 0;
|
||||
ScreenID _lastScreen = ScreenID::BOOT;
|
||||
bool _needsRedraw = true;
|
||||
ScreenID _lastScreen = ScreenID::BOOT;
|
||||
bool _needsRedraw = true;
|
||||
};
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
#pragma once
|
||||
|
||||
#define BOARD_NAME "WS_32E"
|
||||
#define BOARD_NAME "WS_32E"
|
||||
|
||||
// ══════════════════════════════════════════════════════════
|
||||
// TODO: Set these to match YOUR display + wiring.
|
||||
@@ -9,12 +9,12 @@
|
||||
// (which gets copied into the vendored TFT_eSPI library).
|
||||
// ══════════════════════════════════════════════════════════
|
||||
|
||||
#define DISPLAY_WIDTH 320
|
||||
#define DISPLAY_HEIGHT 240
|
||||
#define DISPLAY_ROTATION 1 // landscape
|
||||
#define DISPLAY_WIDTH 320
|
||||
#define DISPLAY_HEIGHT 240
|
||||
#define DISPLAY_ROTATION 1 // landscape
|
||||
|
||||
// Backlight GPIO (directly wired)
|
||||
#define PIN_LCD_BL 22
|
||||
#define PIN_LCD_BL 22
|
||||
|
||||
// Touch — if using XPT2046 via TFT_eSPI, set TOUCH_CS in tft_user_setup.h
|
||||
// If using capacitive touch (e.g. FT6236), configure I2C pins here:
|
||||
|
||||
@@ -2,14 +2,15 @@
|
||||
// Klubhaus Doorbell — ESP32-32E target
|
||||
//
|
||||
|
||||
#include <KlubhausCore.h>
|
||||
#include "DisplayDriverTFT.h"
|
||||
#include "board_config.h"
|
||||
#include "secrets.h"
|
||||
#include "DisplayDriverTFT.h"
|
||||
|
||||
#include <KlubhausCore.h>
|
||||
|
||||
DisplayDriverTFT tftDriver;
|
||||
DisplayManager display(&tftDriver);
|
||||
DoorbellLogic logic(&display);
|
||||
DisplayManager display(&tftDriver);
|
||||
DoorbellLogic logic(&display);
|
||||
|
||||
void setup() {
|
||||
Serial.begin(115200);
|
||||
@@ -31,19 +32,19 @@ void loop() {
|
||||
static int holdStartX = -1;
|
||||
static int holdStartY = -1;
|
||||
|
||||
if (st.deviceState == DeviceState::ALERTING) {
|
||||
if(st.deviceState == DeviceState::ALERTING) {
|
||||
HoldState h = display.updateHold(HOLD_TO_SILENCE_MS);
|
||||
if (h.completed) {
|
||||
if(h.completed) {
|
||||
logic.silenceAlert();
|
||||
holdStartX = -1;
|
||||
holdStartY = -1;
|
||||
}
|
||||
if (h.started) {
|
||||
if(h.started) {
|
||||
TouchEvent t = display.readTouch();
|
||||
holdStartX = t.x;
|
||||
holdStartY = t.y;
|
||||
}
|
||||
if (!h.active && holdStartX >= 0) {
|
||||
if(!h.active && holdStartX >= 0) {
|
||||
display.updateHint(holdStartX, holdStartY);
|
||||
}
|
||||
} else {
|
||||
@@ -51,18 +52,20 @@ void loop() {
|
||||
holdStartY = -1;
|
||||
}
|
||||
|
||||
if (st.screen == ScreenID::DASHBOARD) {
|
||||
if(st.screen == ScreenID::DASHBOARD) {
|
||||
TouchEvent evt = display.readTouch();
|
||||
if (evt.pressed) {
|
||||
if(evt.pressed) {
|
||||
int tile = display.dashboardTouch(evt.x, evt.y);
|
||||
if (tile >= 0) Serial.printf("[DASH] Tile %d tapped\n", tile);
|
||||
if(tile >= 0)
|
||||
Serial.printf("[DASH] Tile %d tapped\n", tile);
|
||||
}
|
||||
}
|
||||
|
||||
// ── Serial console ──
|
||||
if (Serial.available()) {
|
||||
if(Serial.available()) {
|
||||
String cmd = Serial.readStringUntil('\n');
|
||||
cmd.trim();
|
||||
if (cmd.length() > 0) logic.onSerialCommand(cmd);
|
||||
if(cmd.length() > 0)
|
||||
logic.onSerialCommand(cmd);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -11,27 +11,27 @@
|
||||
|
||||
// ── Resolution ──
|
||||
// FIXED: Match board_config.h (320x240 landscape)
|
||||
#define TFT_WIDTH 320
|
||||
#define TFT_WIDTH 320
|
||||
#define TFT_HEIGHT 240
|
||||
|
||||
// ── SPI Pins ──
|
||||
#define TFT_MOSI 23
|
||||
#define TFT_SCLK 18
|
||||
#define TFT_CS 5
|
||||
#define TFT_DC 27
|
||||
#define TFT_RST 33
|
||||
#define TFT_MOSI 23
|
||||
#define TFT_SCLK 18
|
||||
#define TFT_CS 5
|
||||
#define TFT_DC 27
|
||||
#define TFT_RST 33
|
||||
|
||||
// ── Backlight (optional, can also use GPIO directly) ──
|
||||
// #define TFT_BL 22
|
||||
// #define TFT_BACKLIGHT_ON HIGH
|
||||
|
||||
// ── Touch (XPT2046 resistive) ──
|
||||
#define TOUCH_CS 14
|
||||
#define TOUCH_CS 14
|
||||
|
||||
// ── SPI speed ──
|
||||
#define SPI_FREQUENCY 40000000
|
||||
#define SPI_READ_FREQUENCY 20000000
|
||||
#define SPI_TOUCH_FREQUENCY 2500000
|
||||
#define SPI_FREQUENCY 40000000
|
||||
#define SPI_READ_FREQUENCY 20000000
|
||||
#define SPI_TOUCH_FREQUENCY 2500000
|
||||
|
||||
// ── Misc ──
|
||||
#define LOAD_GLCD
|
||||
|
||||
@@ -1,8 +1,9 @@
|
||||
#pragma once
|
||||
|
||||
#include <Arduino.h>
|
||||
#include "IDisplayDriver.h"
|
||||
|
||||
#include <Arduino.h>
|
||||
|
||||
class DisplayDriverGFX : public IDisplayDriver {
|
||||
public:
|
||||
// ── IDisplayDriver ──
|
||||
@@ -27,7 +28,7 @@ private:
|
||||
void drawDashboard(const ScreenState& state);
|
||||
|
||||
// Touch handling
|
||||
TouchEvent _lastTouch = {false, 0, 0};
|
||||
TouchEvent _lastTouch = { false, 0, 0 };
|
||||
unsigned long _pressStartMs = 0;
|
||||
bool _isHolding = false;
|
||||
|
||||
|
||||
@@ -2,117 +2,117 @@
|
||||
|
||||
#define LGFX_USE_V1
|
||||
#include <LovyanGFX.hpp>
|
||||
#include <lgfx/v1/platforms/esp32s3/Panel_RGB.hpp>
|
||||
#include <lgfx/v1/platforms/esp32s3/Bus_RGB.hpp>
|
||||
#include <lgfx/v1/platforms/esp32s3/Panel_RGB.hpp>
|
||||
|
||||
// ── Display dimensions ──
|
||||
#define TFT_HOR_RES 800
|
||||
#define TFT_VER_RES 480
|
||||
#define TFT_HOR_RES 800
|
||||
#define TFT_VER_RES 480
|
||||
|
||||
// ── Touch I2C (from Westcott example) ──
|
||||
#define TOUCH_SDA 8
|
||||
#define TOUCH_SCL 9
|
||||
#define TOUCH_INT 4
|
||||
#define TOUCH_RST -1
|
||||
#define TOUCH_SDA 8
|
||||
#define TOUCH_SCL 9
|
||||
#define TOUCH_INT 4
|
||||
#define TOUCH_RST -1
|
||||
|
||||
// ── CH422G Expander pins ──
|
||||
#define TP_RST 1
|
||||
#define LCD_BL 2
|
||||
#define LCD_RST 3
|
||||
#define SD_CS 4
|
||||
#define USB_SEL 5
|
||||
#define TP_RST 1
|
||||
#define LCD_BL 2
|
||||
#define LCD_RST 3
|
||||
#define SD_CS 4
|
||||
#define USB_SEL 5
|
||||
|
||||
class LGFX : public lgfx::LGFX_Device {
|
||||
public:
|
||||
lgfx::Bus_RGB _bus_instance;
|
||||
lgfx::Panel_RGB _panel_instance;
|
||||
lgfx::Touch_GT911 _touch_instance;
|
||||
lgfx::Bus_RGB _bus_instance;
|
||||
lgfx::Panel_RGB _panel_instance;
|
||||
lgfx::Touch_GT911 _touch_instance;
|
||||
|
||||
LGFX(void) {
|
||||
// Panel config
|
||||
{
|
||||
auto cfg = _panel_instance.config();
|
||||
cfg.memory_width = TFT_HOR_RES;
|
||||
cfg.memory_height = TFT_VER_RES;
|
||||
cfg.panel_width = TFT_HOR_RES;
|
||||
cfg.panel_height = TFT_VER_RES;
|
||||
cfg.offset_x = 0;
|
||||
cfg.offset_y = 0;
|
||||
_panel_instance.config(cfg);
|
||||
LGFX(void) {
|
||||
// Panel config
|
||||
{
|
||||
auto cfg = _panel_instance.config();
|
||||
cfg.memory_width = TFT_HOR_RES;
|
||||
cfg.memory_height = TFT_VER_RES;
|
||||
cfg.panel_width = TFT_HOR_RES;
|
||||
cfg.panel_height = TFT_VER_RES;
|
||||
cfg.offset_x = 0;
|
||||
cfg.offset_y = 0;
|
||||
_panel_instance.config(cfg);
|
||||
}
|
||||
|
||||
// RGB parallel bus config (from Westcott)
|
||||
{
|
||||
auto cfg = _bus_instance.config();
|
||||
cfg.panel = &_panel_instance;
|
||||
|
||||
// Blue channel
|
||||
cfg.pin_d0 = 14;
|
||||
cfg.pin_d1 = 38;
|
||||
cfg.pin_d2 = 18;
|
||||
cfg.pin_d3 = 17;
|
||||
cfg.pin_d4 = 10;
|
||||
|
||||
// Green channel
|
||||
cfg.pin_d5 = 39;
|
||||
cfg.pin_d6 = 0;
|
||||
cfg.pin_d7 = 45;
|
||||
cfg.pin_d8 = 48;
|
||||
cfg.pin_d9 = 47;
|
||||
cfg.pin_d10 = 21;
|
||||
|
||||
// Red channel
|
||||
cfg.pin_d11 = 1;
|
||||
cfg.pin_d12 = 2;
|
||||
cfg.pin_d13 = 42;
|
||||
cfg.pin_d14 = 41;
|
||||
cfg.pin_d15 = 40;
|
||||
|
||||
// Timing
|
||||
cfg.pin_henable = 5;
|
||||
cfg.pin_vsync = 3;
|
||||
cfg.pin_hsync = 46;
|
||||
cfg.pin_pclk = 7;
|
||||
cfg.freq_write = 14000000;
|
||||
|
||||
cfg.hsync_polarity = 0;
|
||||
cfg.hsync_front_porch = 20;
|
||||
cfg.hsync_pulse_width = 10;
|
||||
cfg.hsync_back_porch = 10;
|
||||
|
||||
cfg.vsync_polarity = 0;
|
||||
cfg.vsync_front_porch = 10;
|
||||
cfg.vsync_pulse_width = 10;
|
||||
cfg.vsync_back_porch = 10;
|
||||
|
||||
cfg.pclk_active_neg = 0;
|
||||
cfg.de_idle_high = 0;
|
||||
cfg.pclk_idle_high = 0;
|
||||
|
||||
_bus_instance.config(cfg);
|
||||
}
|
||||
_panel_instance.setBus(&_bus_instance);
|
||||
|
||||
// Touch config (I2C port 1, address 0x14 - from Westcott!)
|
||||
{
|
||||
auto cfg = _touch_instance.config();
|
||||
cfg.x_min = 0;
|
||||
cfg.x_max = TFT_HOR_RES - 1;
|
||||
cfg.y_min = 0;
|
||||
cfg.y_max = TFT_VER_RES - 1;
|
||||
cfg.pin_int = TOUCH_INT;
|
||||
cfg.pin_rst = TOUCH_RST;
|
||||
cfg.bus_shared = false;
|
||||
cfg.offset_rotation = 0;
|
||||
cfg.i2c_port = I2C_NUM_1; // IMPORTANT: Port 1, not 0!
|
||||
cfg.pin_sda = TOUCH_SDA;
|
||||
cfg.pin_scl = TOUCH_SCL;
|
||||
cfg.freq = 400000;
|
||||
cfg.i2c_addr = 0x14; // IMPORTANT: Address 0x14, not 0x5D!
|
||||
_touch_instance.config(cfg);
|
||||
_panel_instance.setTouch(&_touch_instance);
|
||||
}
|
||||
|
||||
setPanel(&_panel_instance);
|
||||
}
|
||||
|
||||
// RGB parallel bus config (from Westcott)
|
||||
{
|
||||
auto cfg = _bus_instance.config();
|
||||
cfg.panel = &_panel_instance;
|
||||
|
||||
// Blue channel
|
||||
cfg.pin_d0 = 14;
|
||||
cfg.pin_d1 = 38;
|
||||
cfg.pin_d2 = 18;
|
||||
cfg.pin_d3 = 17;
|
||||
cfg.pin_d4 = 10;
|
||||
|
||||
// Green channel
|
||||
cfg.pin_d5 = 39;
|
||||
cfg.pin_d6 = 0;
|
||||
cfg.pin_d7 = 45;
|
||||
cfg.pin_d8 = 48;
|
||||
cfg.pin_d9 = 47;
|
||||
cfg.pin_d10 = 21;
|
||||
|
||||
// Red channel
|
||||
cfg.pin_d11 = 1;
|
||||
cfg.pin_d12 = 2;
|
||||
cfg.pin_d13 = 42;
|
||||
cfg.pin_d14 = 41;
|
||||
cfg.pin_d15 = 40;
|
||||
|
||||
// Timing
|
||||
cfg.pin_henable = 5;
|
||||
cfg.pin_vsync = 3;
|
||||
cfg.pin_hsync = 46;
|
||||
cfg.pin_pclk = 7;
|
||||
cfg.freq_write = 14000000;
|
||||
|
||||
cfg.hsync_polarity = 0;
|
||||
cfg.hsync_front_porch = 20;
|
||||
cfg.hsync_pulse_width = 10;
|
||||
cfg.hsync_back_porch = 10;
|
||||
|
||||
cfg.vsync_polarity = 0;
|
||||
cfg.vsync_front_porch = 10;
|
||||
cfg.vsync_pulse_width = 10;
|
||||
cfg.vsync_back_porch = 10;
|
||||
|
||||
cfg.pclk_active_neg = 0;
|
||||
cfg.de_idle_high = 0;
|
||||
cfg.pclk_idle_high = 0;
|
||||
|
||||
_bus_instance.config(cfg);
|
||||
}
|
||||
_panel_instance.setBus(&_bus_instance);
|
||||
|
||||
// Touch config (I2C port 1, address 0x14 - from Westcott!)
|
||||
{
|
||||
auto cfg = _touch_instance.config();
|
||||
cfg.x_min = 0;
|
||||
cfg.x_max = TFT_HOR_RES - 1;
|
||||
cfg.y_min = 0;
|
||||
cfg.y_max = TFT_VER_RES - 1;
|
||||
cfg.pin_int = TOUCH_INT;
|
||||
cfg.pin_rst = TOUCH_RST;
|
||||
cfg.bus_shared = false;
|
||||
cfg.offset_rotation = 0;
|
||||
cfg.i2c_port = I2C_NUM_1; // IMPORTANT: Port 1, not 0!
|
||||
cfg.pin_sda = TOUCH_SDA;
|
||||
cfg.pin_scl = TOUCH_SCL;
|
||||
cfg.freq = 400000;
|
||||
cfg.i2c_addr = 0x14; // IMPORTANT: Address 0x14, not 0x5D!
|
||||
_touch_instance.config(cfg);
|
||||
_panel_instance.setTouch(&_touch_instance);
|
||||
}
|
||||
|
||||
setPanel(&_panel_instance);
|
||||
}
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user