summaryrefslogtreecommitdiff
path: root/src/buttonhandler/ButtonHandler.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/buttonhandler/ButtonHandler.cpp')
-rw-r--r--src/buttonhandler/ButtonHandler.cpp48
1 files changed, 24 insertions, 24 deletions
diff --git a/src/buttonhandler/ButtonHandler.cpp b/src/buttonhandler/ButtonHandler.cpp
index 997409e..b6067d2 100644
--- a/src/buttonhandler/ButtonHandler.cpp
+++ b/src/buttonhandler/ButtonHandler.cpp
@@ -4,7 +4,7 @@ using namespace Pinetime::Controllers;
void ButtonTimerCallback(TimerHandle_t xTimer) {
auto* buttonHandler = static_cast<ButtonHandler*>(pvTimerGetTimerID(xTimer));
- buttonHandler->HandleEvent(ButtonHandler::Timer);
+ buttonHandler->HandleEvent(ButtonHandler::Events::Timer);
}
void ButtonHandler::Init(Pinetime::System::SystemTask* systemTask) {
@@ -12,7 +12,7 @@ void ButtonHandler::Init(Pinetime::System::SystemTask* systemTask) {
buttonTimer = xTimerCreate("buttonTimer", 0, pdFALSE, this, ButtonTimerCallback);
}
-void ButtonHandler::HandleEvent(events event) {
+void ButtonHandler::HandleEvent(Events event) {
static constexpr TickType_t doubleClickTime = pdMS_TO_TICKS(200);
static constexpr TickType_t longPressTime = pdMS_TO_TICKS(400);
static constexpr TickType_t longerPressTime = pdMS_TO_TICKS(2000);
@@ -24,61 +24,61 @@ void ButtonHandler::HandleEvent(events event) {
systemTask->PushMessage(System::Messages::ReloadIdleTimer);
}
- if (event == Press) {
+ if (event == Events::Press) {
buttonPressed = true;
- } else if (event == Release) {
+ } else if (event == Events::Release) {
releaseTime = xTaskGetTickCount();
buttonPressed = false;
}
switch (state) {
- case Idle:
- if (event == Press) {
+ case States::Idle:
+ if (event == Events::Press) {
xTimerChangePeriod(buttonTimer, doubleClickTime, 0);
xTimerStart(buttonTimer, 0);
- state = Pressed;
+ state = States::Pressed;
}
break;
- case Pressed:
- if (event == Press) {
+ case States::Pressed:
+ if (event == Events::Press) {
if (xTaskGetTickCount() - releaseTime < doubleClickTime) {
systemTask->PushMessage(System::Messages::OnButtonDoubleClicked);
xTimerStop(buttonTimer, 0);
- state = Idle;
+ state = States::Idle;
}
- } else if (event == Release) {
+ } else if (event == Events::Release) {
xTimerChangePeriod(buttonTimer, doubleClickTime, 0);
xTimerStart(buttonTimer, 0);
- } else if (event == Timer) {
+ } else if (event == Events::Timer) {
if (buttonPressed) {
xTimerChangePeriod(buttonTimer, longPressTime - doubleClickTime, 0);
xTimerStart(buttonTimer, 0);
- state = Holding;
+ state = States::Holding;
} else {
systemTask->PushMessage(System::Messages::OnButtonPushed);
- state = Idle;
+ state = States::Idle;
}
}
break;
- case Holding:
- if (event == Release) {
+ case States::Holding:
+ if (event == Events::Release) {
systemTask->PushMessage(System::Messages::OnButtonPushed);
xTimerStop(buttonTimer, 0);
- state = Idle;
- } else if (event == Timer) {
+ state = States::Idle;
+ } else if (event == Events::Timer) {
xTimerChangePeriod(buttonTimer, longerPressTime - longPressTime - doubleClickTime, 0);
xTimerStart(buttonTimer, 0);
systemTask->PushMessage(System::Messages::OnButtonLongPressed);
- state = LongHeld;
+ state = States::LongHeld;
}
break;
- case LongHeld:
- if (event == Release) {
+ case States::LongHeld:
+ if (event == Events::Release) {
xTimerStop(buttonTimer, 0);
- state = Idle;
- } else if (event == Timer) {
+ state = States::Idle;
+ } else if (event == Events::Timer) {
systemTask->PushMessage(System::Messages::OnButtonLongerPressed);
- state = Idle;
+ state = States::Idle;
}
break;
}