summaryrefslogtreecommitdiff
path: root/src/touchhandler/TouchHandler.cpp
diff options
context:
space:
mode:
authorRiku Isokoski <riksu9000@gmail.com>2021-07-18 12:32:46 +0300
committerRiku Isokoski <riksu9000@gmail.com>2021-07-18 12:32:46 +0300
commit3e42297bd86fa20daaf7f59f6bc0a69de6cf9e53 (patch)
tree5140d70c4827bcb4bc263d29d28b37e1979e39d9 /src/touchhandler/TouchHandler.cpp
parent329482f87308c185e970b141bcbfe9c83b46c4da (diff)
Update
Diffstat (limited to 'src/touchhandler/TouchHandler.cpp')
-rw-r--r--src/touchhandler/TouchHandler.cpp44
1 files changed, 23 insertions, 21 deletions
diff --git a/src/touchhandler/TouchHandler.cpp b/src/touchhandler/TouchHandler.cpp
index 0d0b8273..187aa696 100644
--- a/src/touchhandler/TouchHandler.cpp
+++ b/src/touchhandler/TouchHandler.cpp
@@ -30,37 +30,39 @@ void TouchHandler::Process(void* instance) {
}
void TouchHandler::Work() {
- Pinetime::Drivers::Cst816S::Gestures prevGesture = Pinetime::Drivers::Cst816S::Gestures::None;
+ bool slideReleased = true;
while (true) {
vTaskSuspend(taskHandle);
info = touchPanel.GetTouchInfo();
- if (info.gesture != Pinetime::Drivers::Cst816S::Gestures::None) {
- if (prevGesture != info.gesture) {
- if (info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideDown || info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideLeft ||
- info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideUp || info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideRight) {
- prevGesture = info.gesture;
+ if (info.isValid) {
+ if (info.gesture != Pinetime::Drivers::Cst816S::Gestures::None) {
+ if (slideReleased) {
+ if (info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideDown ||
+ info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideLeft ||
+ info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideUp ||
+ info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideRight) {
+ slideReleased = false;
+ }
+ gesture = info.gesture;
}
- gesture = info.gesture;
}
- }
- if (systemTask->IsSleeping()) {
- systemTask->PushMessage(System::Messages::TouchWakeUp);
- } else {
- if (info.touching) {
- if (!isCancelled) {
- lvgl.SetNewTouchPoint(info.x, info.y, true);
- }
- } else {
- if (isCancelled) {
- lvgl.SetNewTouchPoint(-1, -1, false);
- isCancelled = false;
+ if (!systemTask->IsSleeping()) {
+ if (info.touching) {
+ if (!isCancelled) {
+ lvgl.SetNewTouchPoint(info.x, info.y, true);
+ }
} else {
- lvgl.SetNewTouchPoint(info.x, info.y, false);
+ if (isCancelled) {
+ lvgl.SetNewTouchPoint(-1, -1, false);
+ isCancelled = false;
+ } else {
+ lvgl.SetNewTouchPoint(info.x, info.y, false);
+ }
+ slideReleased = true;
}
- prevGesture = Pinetime::Drivers::Cst816S::Gestures::None;
}
systemTask->OnTouchEvent();
}