aboutsummaryrefslogtreecommitdiffstats
path: root/src/displayapp/LittleVgl.cpp
diff options
context:
space:
mode:
authorRiku Isokoski <riksu9000@gmail.com>2023-02-23 13:28:04 +0200
committerRiku Isokoski <riksu9000@gmail.com>2023-02-24 00:05:21 +0200
commit7066ff5aba3d2643a35ba98379ff24143da99c3c (patch)
tree79f997e532579529f6c5bcf0be0380d5160db993 /src/displayapp/LittleVgl.cpp
parent6542f255cdb38c5c3baba47ef50993e2c5a2bcc5 (diff)
touchhandler: Remove LVGL dependency
Move LVGL specific code to the LittleVgl class
Diffstat (limited to 'src/displayapp/LittleVgl.cpp')
-rw-r--r--src/displayapp/LittleVgl.cpp31
1 files changed, 25 insertions, 6 deletions
diff --git a/src/displayapp/LittleVgl.cpp b/src/displayapp/LittleVgl.cpp
index cc1223fb..1326c566 100644
--- a/src/displayapp/LittleVgl.cpp
+++ b/src/displayapp/LittleVgl.cpp
@@ -179,15 +179,34 @@ void LittleVgl::FlushDisplay(const lv_area_t* area, lv_color_t* color_p) {
lv_disp_flush_ready(&disp_drv);
}
-void LittleVgl::SetNewTouchPoint(uint16_t x, uint16_t y, bool contact) {
- tap_x = x;
- tap_y = y;
- tapped = contact;
+void LittleVgl::SetNewTouchPoint(int16_t x, int16_t y, bool contact) {
+ if (contact) {
+ if (!isCancelled) {
+ touchPoint = {x, y};
+ tapped = true;
+ }
+ } else {
+ if (isCancelled) {
+ touchPoint = {-1, -1};
+ tapped = false;
+ isCancelled = false;
+ } else {
+ touchPoint = {x, y};
+ tapped = false;
+ }
+ }
+}
+
+void LittleVgl::CancelTap() {
+ if (tapped) {
+ isCancelled = true;
+ touchPoint = {-1, -1};
+ }
}
bool LittleVgl::GetTouchPadInfo(lv_indev_data_t* ptr) {
- ptr->point.x = tap_x;
- ptr->point.y = tap_y;
+ ptr->point.x = touchPoint.x;
+ ptr->point.y = touchPoint.y;
if (tapped) {
ptr->state = LV_INDEV_STATE_PR;
} else {