mirror of
https://github.com/ByteWelder/Tactility.git
synced 2026-02-19 03:13:14 +00:00
Update driver
This commit is contained in:
parent
1de78a6dc6
commit
281fa5f61e
@ -13,11 +13,11 @@
|
|||||||
#include <nvs_flash.h>
|
#include <nvs_flash.h>
|
||||||
#include <rom/ets_sys.h>
|
#include <rom/ets_sys.h>
|
||||||
|
|
||||||
#define TAG "Xpt2046SoftSpi"
|
constexpr auto* TAG = "Xpt2046SoftSpi";
|
||||||
|
|
||||||
#define RERUN_CALIBRATE false
|
constexpr auto RERUN_CALIBRATE = false;
|
||||||
#define CMD_READ_Y 0x90 // Try different commands if these don't work
|
constexpr auto CMD_READ_Y = 0x90; // Try different commands if these don't work
|
||||||
#define CMD_READ_X 0xD0 // Alternative: 0x98 for Y, 0xD8 for X
|
constexpr auto CMD_READ_X = 0xD0; // Alternative: 0x98 for Y, 0xD8 for X
|
||||||
|
|
||||||
struct Calibration {
|
struct Calibration {
|
||||||
int xMin;
|
int xMin;
|
||||||
@ -33,8 +33,6 @@ Calibration cal = {
|
|||||||
.yMax = 1900
|
.yMax = 1900
|
||||||
};
|
};
|
||||||
|
|
||||||
Xpt2046SoftSpi* Xpt2046SoftSpi::instance = nullptr;
|
|
||||||
|
|
||||||
Xpt2046SoftSpi::Xpt2046SoftSpi(std::unique_ptr<Configuration> inConfiguration)
|
Xpt2046SoftSpi::Xpt2046SoftSpi(std::unique_ptr<Configuration> inConfiguration)
|
||||||
: configuration(std::move(inConfiguration)) {
|
: configuration(std::move(inConfiguration)) {
|
||||||
assert(configuration != nullptr);
|
assert(configuration != nullptr);
|
||||||
@ -54,62 +52,7 @@ static void ensureNvsInitialized() {
|
|||||||
initialized = (result == ESP_OK);
|
initialized = (result == ESP_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Xpt2046SoftSpi::start(lv_display_t* display) {
|
bool Xpt2046SoftSpi::startLvgl(lv_display_t* display) {
|
||||||
ensureNvsInitialized();
|
|
||||||
|
|
||||||
TT_LOG_I(TAG, "Starting Xpt2046SoftSpi touch driver");
|
|
||||||
|
|
||||||
// Configure GPIO pins
|
|
||||||
gpio_config_t io_conf = {};
|
|
||||||
|
|
||||||
// Configure MOSI, CLK, CS as outputs
|
|
||||||
io_conf.intr_type = GPIO_INTR_DISABLE;
|
|
||||||
io_conf.mode = GPIO_MODE_OUTPUT;
|
|
||||||
io_conf.pin_bit_mask = (1ULL << configuration->mosiPin) |
|
|
||||||
(1ULL << configuration->clkPin) |
|
|
||||||
(1ULL << configuration->csPin);
|
|
||||||
io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE;
|
|
||||||
io_conf.pull_up_en = GPIO_PULLUP_DISABLE;
|
|
||||||
|
|
||||||
if (gpio_config(&io_conf) != ESP_OK) {
|
|
||||||
TT_LOG_E(TAG, "Failed to configure output pins");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Configure MISO as input
|
|
||||||
io_conf.mode = GPIO_MODE_INPUT;
|
|
||||||
io_conf.pin_bit_mask = (1ULL << configuration->misoPin);
|
|
||||||
io_conf.pull_up_en = GPIO_PULLUP_ENABLE;
|
|
||||||
|
|
||||||
if (gpio_config(&io_conf) != ESP_OK) {
|
|
||||||
TT_LOG_E(TAG, "Failed to configure input pin");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize pin states
|
|
||||||
gpio_set_level(configuration->csPin, 1); // CS high
|
|
||||||
gpio_set_level(configuration->clkPin, 0); // CLK low
|
|
||||||
gpio_set_level(configuration->mosiPin, 0); // MOSI low
|
|
||||||
|
|
||||||
TT_LOG_I(TAG, "GPIO configured: MOSI=%d, MISO=%d, CLK=%d, CS=%d", configuration->mosiPin, configuration->misoPin, configuration->clkPin, configuration->csPin);
|
|
||||||
|
|
||||||
// Load or perform calibration
|
|
||||||
bool calibrationValid = true; //loadCalibration() && !RERUN_CALIBRATE;
|
|
||||||
if (calibrationValid) {
|
|
||||||
// Check if calibration values are valid (xMin != xMax, yMin != yMax)
|
|
||||||
if (cal.xMin == cal.xMax || cal.yMin == cal.yMax) {
|
|
||||||
TT_LOG_W(TAG, "Invalid calibration detected: xMin=%d, xMax=%d, yMin=%d, yMax=%d", cal.xMin, cal.xMax, cal.yMin, cal.yMax);
|
|
||||||
calibrationValid = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!calibrationValid) {
|
|
||||||
TT_LOG_W(TAG, "Calibration data not found, invalid, or forced recalibration");
|
|
||||||
calibrate();
|
|
||||||
saveCalibration();
|
|
||||||
} else {
|
|
||||||
TT_LOG_I(TAG, "Loaded calibration: xMin=%d, yMin=%d, xMax=%d, yMax=%d", cal.xMin, cal.yMin, cal.xMax, cal.yMax);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create LVGL input device
|
// Create LVGL input device
|
||||||
deviceHandle = lv_indev_create();
|
deviceHandle = lv_indev_create();
|
||||||
@ -117,27 +60,24 @@ bool Xpt2046SoftSpi::start(lv_display_t* display) {
|
|||||||
TT_LOG_E(TAG, "Failed to create LVGL input device");
|
TT_LOG_E(TAG, "Failed to create LVGL input device");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
lv_indev_set_type(deviceHandle, LV_INDEV_TYPE_POINTER);
|
lv_indev_set_type(deviceHandle, LV_INDEV_TYPE_POINTER);
|
||||||
lv_indev_set_read_cb(deviceHandle, touchReadCallback);
|
lv_indev_set_read_cb(deviceHandle, touchReadCallback);
|
||||||
lv_indev_set_user_data(deviceHandle, this);
|
lv_indev_set_user_data(deviceHandle, this);
|
||||||
|
|
||||||
instance = this;
|
|
||||||
TT_LOG_I(TAG, "Xpt2046SoftSpi touch driver started successfully");
|
TT_LOG_I(TAG, "Xpt2046SoftSpi touch driver started successfully");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Xpt2046SoftSpi::stop() {
|
bool Xpt2046SoftSpi::stop() {
|
||||||
TT_LOG_I(TAG, "Stopping Xpt2046SoftSpi touch driver");
|
TT_LOG_I(TAG, "Stopping Xpt2046SoftSpi touch driver");
|
||||||
instance = nullptr;
|
|
||||||
cleanup();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Xpt2046SoftSpi::cleanup() {
|
// Stop LVLG if needed
|
||||||
if (deviceHandle != nullptr) {
|
if (deviceHandle != nullptr) {
|
||||||
lv_indev_delete(deviceHandle);
|
stopLvgl();
|
||||||
deviceHandle = nullptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int Xpt2046SoftSpi::readSPI(uint8_t command) {
|
int Xpt2046SoftSpi::readSPI(uint8_t command) {
|
||||||
@ -338,10 +278,64 @@ void Xpt2046SoftSpi::touchReadCallback(lv_indev_t* indev, lv_indev_data_t* data)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Zero-argument start
|
|
||||||
bool Xpt2046SoftSpi::start() {
|
bool Xpt2046SoftSpi::start() {
|
||||||
// Default to LVGL-less startup if needed
|
ensureNvsInitialized();;
|
||||||
return startLvgl(nullptr);
|
|
||||||
|
TT_LOG_I(TAG, "Starting Xpt2046SoftSpi touch driver");
|
||||||
|
|
||||||
|
// Configure GPIO pins
|
||||||
|
gpio_config_t io_conf = {};
|
||||||
|
|
||||||
|
// Configure MOSI, CLK, CS as outputs
|
||||||
|
io_conf.intr_type = GPIO_INTR_DISABLE;
|
||||||
|
io_conf.mode = GPIO_MODE_OUTPUT;
|
||||||
|
io_conf.pin_bit_mask = (1ULL << configuration->mosiPin) |
|
||||||
|
(1ULL << configuration->clkPin) |
|
||||||
|
(1ULL << configuration->csPin);
|
||||||
|
io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE;
|
||||||
|
io_conf.pull_up_en = GPIO_PULLUP_DISABLE;
|
||||||
|
|
||||||
|
if (gpio_config(&io_conf) != ESP_OK) {
|
||||||
|
TT_LOG_E(TAG, "Failed to configure output pins");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Configure MISO as input
|
||||||
|
io_conf.mode = GPIO_MODE_INPUT;
|
||||||
|
io_conf.pin_bit_mask = (1ULL << configuration->misoPin);
|
||||||
|
io_conf.pull_up_en = GPIO_PULLUP_ENABLE;
|
||||||
|
|
||||||
|
if (gpio_config(&io_conf) != ESP_OK) {
|
||||||
|
TT_LOG_E(TAG, "Failed to configure input pin");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Initialize pin states
|
||||||
|
gpio_set_level(configuration->csPin, 1); // CS high
|
||||||
|
gpio_set_level(configuration->clkPin, 0); // CLK low
|
||||||
|
gpio_set_level(configuration->mosiPin, 0); // MOSI low
|
||||||
|
|
||||||
|
TT_LOG_I(TAG, "GPIO configured: MOSI=%d, MISO=%d, CLK=%d, CS=%d", configuration->mosiPin, configuration->misoPin, configuration->clkPin, configuration->csPin);
|
||||||
|
|
||||||
|
// Load or perform calibration
|
||||||
|
bool calibrationValid = true; //loadCalibration() && !RERUN_CALIBRATE;
|
||||||
|
if (calibrationValid) {
|
||||||
|
// Check if calibration values are valid (xMin != xMax, yMin != yMax)
|
||||||
|
if (cal.xMin == cal.xMax || cal.yMin == cal.yMax) {
|
||||||
|
TT_LOG_W(TAG, "Invalid calibration detected: xMin=%d, xMax=%d, yMin=%d, yMax=%d", cal.xMin, cal.xMax, cal.yMin, cal.yMax);
|
||||||
|
calibrationValid = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!calibrationValid) {
|
||||||
|
TT_LOG_W(TAG, "Calibration data not found, invalid, or forced recalibration");
|
||||||
|
calibrate();
|
||||||
|
saveCalibration();
|
||||||
|
} else {
|
||||||
|
TT_LOG_I(TAG, "Loaded calibration: xMin=%d, yMin=%d, xMax=%d, yMax=%d", cal.xMin, cal.yMin, cal.xMax, cal.yMax);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Whether this device supports LVGL
|
// Whether this device supports LVGL
|
||||||
@ -349,19 +343,12 @@ bool Xpt2046SoftSpi::supportsLvgl() const {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Start with LVGL display
|
|
||||||
bool Xpt2046SoftSpi::startLvgl(lv_display_t* display) {
|
|
||||||
return start(display);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Stop LVGL
|
// Stop LVGL
|
||||||
bool Xpt2046SoftSpi::stopLvgl() {
|
bool Xpt2046SoftSpi::stopLvgl() {
|
||||||
cleanup();
|
if (deviceHandle != nullptr) {
|
||||||
return true;
|
lv_indev_delete(deviceHandle);
|
||||||
}
|
deviceHandle = nullptr;
|
||||||
|
}
|
||||||
// Supports a separate touch driver? Yes/No
|
|
||||||
bool Xpt2046SoftSpi::supportsTouchDriver() {
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -2,12 +2,8 @@
|
|||||||
|
|
||||||
#include "Tactility/hal/touch/TouchDevice.h"
|
#include "Tactility/hal/touch/TouchDevice.h"
|
||||||
#include "Tactility/hal/touch/TouchDriver.h"
|
#include "Tactility/hal/touch/TouchDriver.h"
|
||||||
#include <Tactility/TactilityCore.h>
|
|
||||||
#include "lvgl.h"
|
#include "lvgl.h"
|
||||||
#include <driver/gpio.h>
|
#include <driver/gpio.h>
|
||||||
#include <esp_err.h>
|
|
||||||
#include <freertos/FreeRTOS.h>
|
|
||||||
#include <freertos/task.h>
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
@ -61,12 +57,10 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static Xpt2046SoftSpi* instance;
|
|
||||||
std::unique_ptr<Configuration> configuration;
|
std::unique_ptr<Configuration> configuration;
|
||||||
lv_indev_t* deviceHandle = nullptr;
|
lv_indev_t* deviceHandle = nullptr;
|
||||||
|
|
||||||
int readSPI(uint8_t command);
|
int readSPI(uint8_t command);
|
||||||
void cleanup();
|
|
||||||
bool loadCalibration();
|
bool loadCalibration();
|
||||||
void saveCalibration();
|
void saveCalibration();
|
||||||
static void touchReadCallback(lv_indev_t* indev, lv_indev_data_t* data);
|
static void touchReadCallback(lv_indev_t* indev, lv_indev_data_t* data);
|
||||||
@ -78,24 +72,20 @@ public:
|
|||||||
std::string getName() const final { return "Xpt2046SoftSpi"; }
|
std::string getName() const final { return "Xpt2046SoftSpi"; }
|
||||||
std::string getDescription() const final { return "Xpt2046 Soft SPI touch driver"; }
|
std::string getDescription() const final { return "Xpt2046 Soft SPI touch driver"; }
|
||||||
|
|
||||||
bool start() override; // zero-arg start
|
bool start() override;
|
||||||
|
bool stop() override;
|
||||||
|
|
||||||
bool supportsLvgl() const override;
|
bool supportsLvgl() const override;
|
||||||
bool startLvgl(lv_display_t* display) override;
|
bool startLvgl(lv_display_t* display) override;
|
||||||
bool stopLvgl() override;
|
bool stopLvgl() override;
|
||||||
bool stop() override;
|
|
||||||
bool supportsTouchDriver() override;
|
bool supportsTouchDriver() override { return true; }
|
||||||
std::shared_ptr<tt::hal::touch::TouchDriver> getTouchDriver() override;
|
std::shared_ptr<tt::hal::touch::TouchDriver> getTouchDriver() override;
|
||||||
lv_indev_t* getLvglIndev() override { return deviceHandle; }
|
lv_indev_t* getLvglIndev() override { return deviceHandle; }
|
||||||
|
|
||||||
// Original LVGL-specific start
|
|
||||||
bool start(lv_display_t* display);
|
|
||||||
|
|
||||||
// XPT2046-specific methods
|
// XPT2046-specific methods
|
||||||
Point getTouch();
|
Point getTouch();
|
||||||
void calibrate();
|
void calibrate();
|
||||||
void setCalibration(int xMin, int yMin, int xMax, int yMax);
|
void setCalibration(int xMin, int yMin, int xMax, int yMax);
|
||||||
bool isTouched();
|
bool isTouched();
|
||||||
|
|
||||||
// Static instance access
|
|
||||||
static Xpt2046SoftSpi* getInstance() { return instance; }
|
|
||||||
};
|
};
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user