1
0
Fork 0

Optimize SettingWakeUp

This commit is contained in:
Riku Isokoski 2022-10-13 21:24:48 +03:00 committed by JF
parent 9c5b1437ec
commit 99b5b49993
2 changed files with 42 additions and 67 deletions

View file

@ -4,19 +4,23 @@
#include "displayapp/screens/Screen.h" #include "displayapp/screens/Screen.h"
#include "displayapp/screens/Symbols.h" #include "displayapp/screens/Symbols.h"
#include "components/settings/Settings.h" #include "components/settings/Settings.h"
#include "displayapp/screens/Styles.h"
using namespace Pinetime::Applications::Screens; using namespace Pinetime::Applications::Screens;
constexpr std::array<SettingWakeUp::Option, 4> SettingWakeUp::options;
namespace { namespace {
void event_handler(lv_obj_t* obj, lv_event_t event) { void event_handler(lv_obj_t* obj, lv_event_t event) {
auto* screen = static_cast<SettingWakeUp*>(obj->user_data); auto* screen = static_cast<SettingWakeUp*>(obj->user_data);
screen->UpdateSelected(obj, event); if (event == LV_EVENT_VALUE_CHANGED) {
screen->UpdateSelected(obj);
}
} }
} }
SettingWakeUp::SettingWakeUp(Pinetime::Applications::DisplayApp* app, Pinetime::Controllers::Settings& settingsController) SettingWakeUp::SettingWakeUp(Pinetime::Applications::DisplayApp* app, Pinetime::Controllers::Settings& settingsController)
: Screen(app), settingsController {settingsController} { : Screen(app), settingsController {settingsController} {
ignoringEvents = false;
lv_obj_t* container1 = lv_cont_create(lv_scr_act(), nullptr); lv_obj_t* container1 = lv_cont_create(lv_scr_act(), nullptr);
lv_obj_set_style_local_bg_opa(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, LV_OPA_TRANSP); lv_obj_set_style_local_bg_opa(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, LV_OPA_TRANSP);
@ -40,39 +44,15 @@ SettingWakeUp::SettingWakeUp(Pinetime::Applications::DisplayApp* app, Pinetime::
lv_label_set_align(icon, LV_LABEL_ALIGN_CENTER); lv_label_set_align(icon, LV_LABEL_ALIGN_CENTER);
lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0); lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0);
optionsTotal = 0; for (unsigned int i = 0; i < options.size(); i++) {
cbOption[optionsTotal] = lv_checkbox_create(container1, nullptr); cbOption[i] = lv_checkbox_create(container1, nullptr);
lv_checkbox_set_text_static(cbOption[optionsTotal], "Single Tap"); lv_checkbox_set_text(cbOption[i], options[i].name);
cbOption[optionsTotal]->user_data = this; if (settingsController.isWakeUpModeOn(static_cast<Controllers::Settings::WakeUpMode>(i))) {
lv_obj_set_event_cb(cbOption[optionsTotal], event_handler); lv_checkbox_set_checked(cbOption[i], true);
if (settingsController.isWakeUpModeOn(Pinetime::Controllers::Settings::WakeUpMode::SingleTap)) { }
lv_checkbox_set_checked(cbOption[optionsTotal], true); cbOption[i]->user_data = this;
lv_obj_set_event_cb(cbOption[i], event_handler);
} }
optionsTotal++;
cbOption[optionsTotal] = lv_checkbox_create(container1, nullptr);
lv_checkbox_set_text_static(cbOption[optionsTotal], "Double Tap");
cbOption[optionsTotal]->user_data = this;
lv_obj_set_event_cb(cbOption[optionsTotal], event_handler);
if (settingsController.isWakeUpModeOn(Pinetime::Controllers::Settings::WakeUpMode::DoubleTap)) {
lv_checkbox_set_checked(cbOption[optionsTotal], true);
}
optionsTotal++;
cbOption[optionsTotal] = lv_checkbox_create(container1, nullptr);
lv_checkbox_set_text_static(cbOption[optionsTotal], "Raise Wrist");
cbOption[optionsTotal]->user_data = this;
lv_obj_set_event_cb(cbOption[optionsTotal], event_handler);
if (settingsController.isWakeUpModeOn(Pinetime::Controllers::Settings::WakeUpMode::RaiseWrist)) {
lv_checkbox_set_checked(cbOption[optionsTotal], true);
}
optionsTotal++;
cbOption[optionsTotal] = lv_checkbox_create(container1, nullptr);
lv_checkbox_set_text_static(cbOption[optionsTotal], "Shake Wake");
cbOption[optionsTotal]->user_data = this;
lv_obj_set_event_cb(cbOption[optionsTotal], event_handler);
if (settingsController.isWakeUpModeOn(Pinetime::Controllers::Settings::WakeUpMode::Shake)) {
lv_checkbox_set_checked(cbOption[optionsTotal], true);
}
optionsTotal++;
} }
SettingWakeUp::~SettingWakeUp() { SettingWakeUp::~SettingWakeUp() {
@ -80,32 +60,21 @@ SettingWakeUp::~SettingWakeUp() {
settingsController.SaveSettings(); settingsController.SaveSettings();
} }
void SettingWakeUp::UpdateSelected(lv_obj_t* object, lv_event_t event) { void SettingWakeUp::UpdateSelected(lv_obj_t* object) {
using WakeUpMode = Pinetime::Controllers::Settings::WakeUpMode; // Find the index of the checkbox that triggered the event
if (event == LV_EVENT_VALUE_CHANGED && !ignoringEvents) { for (size_t i = 0; i < options.size(); i++) {
ignoringEvents = true; if (cbOption[i] == object) {
bool currentState = settingsController.isWakeUpModeOn(options[i].wakeUpMode);
// Find the index of the checkbox that triggered the event settingsController.setWakeUpMode(options[i].wakeUpMode, !currentState);
int index = 0; break;
for (; index < optionsTotal; ++index) {
if (cbOption[index] == object) {
break;
}
} }
}
// Toggle needed wakeup mode // Update checkbox according to current wakeup modes.
auto mode = static_cast<WakeUpMode>(index); // This is needed because we can have extra logic when setting or unsetting wakeup modes,
auto currentState = settingsController.isWakeUpModeOn(mode); // for example, when setting SingleTap, DoubleTap is unset and vice versa.
settingsController.setWakeUpMode(mode, !currentState); auto modes = settingsController.getWakeUpModes();
for (size_t i = 0; i < options.size(); ++i) {
// Update checkbox according to current wakeup modes. lv_checkbox_set_checked(cbOption[i], modes[i]);
// This is needed because we can have extra logic when setting or unsetting wakeup modes,
// for example, when setting SingleTap, DoubleTap is unset and vice versa.
auto modes = settingsController.getWakeUpModes();
for (int i = 0; i < optionsTotal; ++i) {
lv_checkbox_set_checked(cbOption[i], modes[i]);
}
ignoringEvents = false;
} }
} }

View file

@ -1,5 +1,6 @@
#pragma once #pragma once
#include <array>
#include <cstdint> #include <cstdint>
#include <lvgl/lvgl.h> #include <lvgl/lvgl.h>
#include "components/settings/Settings.h" #include "components/settings/Settings.h"
@ -15,17 +16,22 @@ namespace Pinetime {
SettingWakeUp(DisplayApp* app, Pinetime::Controllers::Settings& settingsController); SettingWakeUp(DisplayApp* app, Pinetime::Controllers::Settings& settingsController);
~SettingWakeUp() override; ~SettingWakeUp() override;
void UpdateSelected(lv_obj_t* object, lv_event_t event); void UpdateSelected(lv_obj_t* object);
private: private:
struct Option {
Controllers::Settings::WakeUpMode wakeUpMode;
const char* name;
};
Controllers::Settings& settingsController; Controllers::Settings& settingsController;
uint8_t optionsTotal; static constexpr std::array<Option, 4> options = {{
lv_obj_t* cbOption[5]; {Controllers::Settings::WakeUpMode::SingleTap, "Single Tap"},
// When UpdateSelected is called, it uses lv_checkbox_set_checked, {Controllers::Settings::WakeUpMode::DoubleTap, "Double Tap"},
// which can cause extra events to be fired, {Controllers::Settings::WakeUpMode::RaiseWrist, "Raise Wrist"},
// which might trigger UpdateSelected again, causing a loop. {Controllers::Settings::WakeUpMode::Shake, "Shake Wake"},
// This variable is used as a mutex to prevent that. }};
bool ignoringEvents;
lv_obj_t* cbOption[options.size()];
}; };
} }
} }