mirror of
https://github.com/Threnklyn/esphome-dev.git
synced 2026-05-21 13:33:27 +02:00
5393a09872
* Introduce calibration settings for all touchscreen drivers. this will override the common values. The x,y coordinates only calculated when the right calibrations are set. * resolve issues reported by CI * remove unneeded spaces and newlines * Forgot to remove some obsolete code * remove get_setup_priority from xpt2046 * remove media_player changes. * media_player: removed to much, * Update suggestions * referd back the `get_setup_priority` removal so it can be moved into a othe PR. * tt21100: restore init read * fix spacing * load native display dimensions instead of using internal dimensons. and load it only onse on setup * moved `update_touches()` to protexted section * adding Clydes PR#6049 * add multitouch test script * Update all Touchscreen replacing `get_*_internal` to `get_native_*` * fixed some CI recomendations * couple of fixes * make sure the display is running before touchscreen is setup * fix clang * revert back last changes * xpt2046: change log level for testing * logging information * add test file * fix polling issue with the for example the xpt2046 * fixed some CI issues * fixed some CI issues * restore mirror parameter discriptions * same for the swap_xy * same for the transform * remove the above const from const.py * and put the above const bacl const.py * Merge branch 'nvds-touchscreen-fix1' of https://github.com/nielsnl68/esphome into nvds-touchscreen-fix1 * and put the above const bacl const.py * [tt21100] making interupt pin optional * [tt21100] making interupt pin optional (now complete) * update the display part based on @clyde' s changes. * fix issue with ft6x36 touvhscreen * reverd back touch check. add comment * add some extra checks to the ft6x36 * add an other log and a typo fixed * okay an other fix. * add an extra check like others do and fix data type * [ft6336] fix update race when ts is touched. * [touchscreen] update some log's with a verbose level. * fix clang issues * fix the clang issues * fix the clang issues * fix virtual issue. * fix the clang issues * an other clang issues * remove anti-aliased fonts support. It does not belong here. * remove anti-aliased fonts support. It does not belong here. * rename test script * Moving the test files to there right location. * rename the test files * clean up the code * add a new line * clang fixings * clang fixings * remove comment * remove comment * Update esphome/components/touchscreen/__init__.py Co-authored-by: guillempages <guillempages@users.noreply.github.com> * Update esphome/components/touchscreen/__init__.py Co-authored-by: guillempages <guillempages@users.noreply.github.com> * Update esphome/components/touchscreen/__init__.py Co-authored-by: guillempages <guillempages@users.noreply.github.com> * Update esphome/components/touchscreen/touchscreen.cpp * Update esphome/components/touchscreen/touchscreen.cpp * [ft63x6] add threshold --------- Co-authored-by: Clyde Stubbs <2366188+clydebarrow@users.noreply.github.com> Co-authored-by: guillempages <guillempages@users.noreply.github.com>
117 lines
3.8 KiB
C++
117 lines
3.8 KiB
C++
#include "gt911_touchscreen.h"
|
|
|
|
#include "esphome/core/helpers.h"
|
|
#include "esphome/core/log.h"
|
|
|
|
namespace esphome {
|
|
namespace gt911 {
|
|
|
|
static const char *const TAG = "gt911.touchscreen";
|
|
|
|
static const uint8_t GET_TOUCH_STATE[2] = {0x81, 0x4E};
|
|
static const uint8_t CLEAR_TOUCH_STATE[3] = {0x81, 0x4E, 0x00};
|
|
static const uint8_t GET_TOUCHES[2] = {0x81, 0x4F};
|
|
static const uint8_t GET_SWITCHES[2] = {0x80, 0x4D};
|
|
static const uint8_t GET_MAX_VALUES[2] = {0x80, 0x48};
|
|
static const size_t MAX_TOUCHES = 5; // max number of possible touches reported
|
|
static const size_t MAX_BUTTONS = 4; // max number of buttons scanned
|
|
|
|
#define ERROR_CHECK(err) \
|
|
if ((err) != i2c::ERROR_OK) { \
|
|
ESP_LOGE(TAG, "Failed to communicate!"); \
|
|
this->status_set_warning(); \
|
|
return; \
|
|
}
|
|
|
|
void GT911Touchscreen::setup() {
|
|
i2c::ErrorCode err;
|
|
ESP_LOGCONFIG(TAG, "Setting up GT911 Touchscreen...");
|
|
|
|
// check the configuration of the int line.
|
|
uint8_t data[4];
|
|
err = this->write(GET_SWITCHES, 2);
|
|
if (err == i2c::ERROR_OK) {
|
|
err = this->read(data, 1);
|
|
if (err == i2c::ERROR_OK) {
|
|
ESP_LOGD(TAG, "Read from switches: 0x%02X", data[0]);
|
|
if (this->interrupt_pin_ != nullptr) {
|
|
// datasheet says NOT to use pullup/down on the int line.
|
|
this->interrupt_pin_->pin_mode(gpio::FLAG_INPUT);
|
|
this->interrupt_pin_->setup();
|
|
this->attach_interrupt_(this->interrupt_pin_,
|
|
(data[0] & 1) ? gpio::INTERRUPT_FALLING_EDGE : gpio::INTERRUPT_RISING_EDGE);
|
|
}
|
|
}
|
|
}
|
|
if (err == i2c::ERROR_OK) {
|
|
err = this->write(GET_MAX_VALUES, 2);
|
|
if (err == i2c::ERROR_OK) {
|
|
err = this->read(data, sizeof(data));
|
|
if (err == i2c::ERROR_OK) {
|
|
if (this->x_raw_max_ == this->x_raw_min_) {
|
|
this->x_raw_max_ = encode_uint16(data[1], data[0]);
|
|
}
|
|
if (this->y_raw_max_ == this->y_raw_min_) {
|
|
this->y_raw_max_ = encode_uint16(data[3], data[2]);
|
|
}
|
|
esph_log_d(TAG, "calibration max_x/max_y %d/%d", this->x_raw_max_, this->y_raw_max_);
|
|
}
|
|
}
|
|
}
|
|
if (err != i2c::ERROR_OK) {
|
|
ESP_LOGE(TAG, "Failed to communicate!");
|
|
this->mark_failed();
|
|
return;
|
|
}
|
|
|
|
ESP_LOGCONFIG(TAG, "GT911 Touchscreen setup complete");
|
|
}
|
|
|
|
void GT911Touchscreen::update_touches() {
|
|
i2c::ErrorCode err;
|
|
uint8_t touch_state = 0;
|
|
uint8_t data[MAX_TOUCHES + 1][8]; // 8 bytes each for each point, plus extra space for the key byte
|
|
|
|
err = this->write(GET_TOUCH_STATE, sizeof(GET_TOUCH_STATE), false);
|
|
ERROR_CHECK(err);
|
|
err = this->read(&touch_state, 1);
|
|
ERROR_CHECK(err);
|
|
this->write(CLEAR_TOUCH_STATE, sizeof(CLEAR_TOUCH_STATE));
|
|
uint8_t num_of_touches = touch_state & 0x07;
|
|
|
|
if ((touch_state & 0x80) == 0 || num_of_touches > MAX_TOUCHES) {
|
|
this->skip_update_ = true; // skip send touch events, touchscreen is not ready yet.
|
|
return;
|
|
}
|
|
|
|
err = this->write(GET_TOUCHES, sizeof(GET_TOUCHES), false);
|
|
ERROR_CHECK(err);
|
|
// num_of_touches is guaranteed to be 0..5. Also read the key data
|
|
err = this->read(data[0], sizeof(data[0]) * num_of_touches + 1);
|
|
ERROR_CHECK(err);
|
|
|
|
for (uint8_t i = 0; i != num_of_touches; i++) {
|
|
uint16_t id = data[i][0];
|
|
uint16_t x = encode_uint16(data[i][2], data[i][1]);
|
|
uint16_t y = encode_uint16(data[i][4], data[i][3]);
|
|
this->add_raw_touch_position_(id, x, y);
|
|
}
|
|
auto keys = data[num_of_touches][0] & ((1 << MAX_BUTTONS) - 1);
|
|
if (keys != this->button_state_) {
|
|
this->button_state_ = keys;
|
|
for (size_t i = 0; i != MAX_BUTTONS; i++) {
|
|
for (auto *listener : this->button_listeners_)
|
|
listener->update_button(i, (keys & (1 << i)) != 0);
|
|
}
|
|
}
|
|
}
|
|
|
|
void GT911Touchscreen::dump_config() {
|
|
ESP_LOGCONFIG(TAG, "GT911 Touchscreen:");
|
|
LOG_I2C_DEVICE(this);
|
|
LOG_PIN(" Interrupt Pin: ", this->interrupt_pin_);
|
|
}
|
|
|
|
} // namespace gt911
|
|
} // namespace esphome
|