summaryrefslogtreecommitdiff
path: root/src/touchhandler/TouchHandler.cpp
diff options
context:
space:
mode:
authorReinhold Gschweicher <pyro4hell@gmail.com>2022-01-16 23:37:15 +0100
committerJF <JF002@users.noreply.github.com>2022-04-13 21:33:58 +0200
commit2607c3d79947e900ce4c5ded296f649677511a34 (patch)
treecb22b11d9df9296921f8ec33be2393f664e471f5 /src/touchhandler/TouchHandler.cpp
parentb498e1d633522eed975d78b04508834b7a79befe (diff)
Let TouchHandler return TouchEvents instead of driver specific enum
Let the TouchHandler::GestureGet() function return a TouchEvent instead of the touchpanel-driver specific enum. This helps to move the driver specific helper function `ConvertGesture` from `DisplayApp` into `TouchHandler`.
Diffstat (limited to 'src/touchhandler/TouchHandler.cpp')
-rw-r--r--src/touchhandler/TouchHandler.cpp38
1 files changed, 34 insertions, 4 deletions
diff --git a/src/touchhandler/TouchHandler.cpp b/src/touchhandler/TouchHandler.cpp
index 0be33476..0e4fb541 100644
--- a/src/touchhandler/TouchHandler.cpp
+++ b/src/touchhandler/TouchHandler.cpp
@@ -1,6 +1,36 @@
#include "touchhandler/TouchHandler.h"
+#ifdef PINETIME_IS_RECOVERY
+ #include "displayapp/DummyLittleVgl.h"
+#else
+ #include "displayapp/LittleVgl.h"
+#endif
using namespace Pinetime::Controllers;
+using namespace Pinetime::Applications;
+
+namespace {
+ TouchEvents ConvertGesture(Pinetime::Drivers::Cst816S::Gestures gesture) {
+ switch (gesture) {
+ case Pinetime::Drivers::Cst816S::Gestures::SingleTap:
+ return TouchEvents::Tap;
+ case Pinetime::Drivers::Cst816S::Gestures::LongPress:
+ return TouchEvents::LongTap;
+ case Pinetime::Drivers::Cst816S::Gestures::DoubleTap:
+ return TouchEvents::DoubleTap;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideRight:
+ return TouchEvents::SwipeRight;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideLeft:
+ return TouchEvents::SwipeLeft;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideDown:
+ return TouchEvents::SwipeDown;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideUp:
+ return TouchEvents::SwipeUp;
+ case Pinetime::Drivers::Cst816S::Gestures::None:
+ default:
+ return TouchEvents::None;
+ }
+ }
+}
TouchHandler::TouchHandler(Drivers::Cst816S& touchPanel, Components::LittleVgl& lvgl) : touchPanel {touchPanel}, lvgl {lvgl} {
}
@@ -12,9 +42,9 @@ void TouchHandler::CancelTap() {
}
}
-Pinetime::Drivers::Cst816S::Gestures TouchHandler::GestureGet() {
+Pinetime::Applications::TouchEvents TouchHandler::GestureGet() {
auto returnGesture = gesture;
- gesture = Drivers::Cst816S::Gestures::None;
+ gesture = Pinetime::Applications::TouchEvents::None;
return returnGesture;
}
@@ -33,11 +63,11 @@ bool TouchHandler::GetNewTouchInfo() {
info.gesture == Pinetime::Drivers::Cst816S::Gestures::SlideRight ||
info.gesture == Pinetime::Drivers::Cst816S::Gestures::LongPress) {
if (info.touching) {
- gesture = info.gesture;
+ gesture = ConvertGesture(info.gesture);
gestureReleased = false;
}
} else {
- gesture = info.gesture;
+ gesture = ConvertGesture(info.gesture);
}
}
}