-
-
Notifications
You must be signed in to change notification settings - Fork 952
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update `CheckboxList.h` to optionally be able to get checkboxes (instead of the default of radio-buttons) and be able to have multi-selection through a new callback. Use these updated capabilities of `CheckboxList.h` to replace the nearly identical code of `SettingWakeUp.h` One noticable change is that previously all 5 wake-up-settings were on the same page. But with this PR and the default value of 4 settings per screen on `CheckboxList.h` we have two pages.
- Loading branch information
1 parent
c8236af
commit d5e3dff
Showing
5 changed files
with
112 additions
and
78 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,79 +1,66 @@ | ||
#include "displayapp/screens/settings/SettingWakeUp.h" | ||
#include <lvgl/lvgl.h> | ||
#include "displayapp/DisplayApp.h" | ||
|
||
#include "displayapp/screens/Screen.h" | ||
#include "displayapp/screens/Symbols.h" | ||
#include "components/settings/Settings.h" | ||
#include "displayapp/screens/CheckboxList.h" | ||
#include "displayapp/screens/Styles.h" | ||
|
||
using namespace Pinetime::Applications::Screens; | ||
|
||
constexpr std::array<SettingWakeUp::Option, 5> SettingWakeUp::options; | ||
constexpr const char* SettingWakeUp::title; | ||
constexpr const char* SettingWakeUp::symbol; | ||
|
||
constexpr std::array<SettingWakeUp::Option, SettingWakeUp::optionsCount> SettingWakeUp::options; | ||
|
||
namespace { | ||
void event_handler(lv_obj_t* obj, lv_event_t event) { | ||
auto* screen = static_cast<SettingWakeUp*>(obj->user_data); | ||
if (event == LV_EVENT_VALUE_CHANGED) { | ||
screen->UpdateSelected(obj); | ||
std::unique_ptr<Screen> SettingWakeUp::CreateScreen(unsigned int screenNum) const { | ||
std::array<Screens::CheckboxList::Item, settingsPerScreen> optionsOnThisScreen; | ||
for (int i = 0; i < settingsPerScreen; i++) { | ||
if (i + (screenNum * settingsPerScreen) >= options.size()) { | ||
optionsOnThisScreen[i] = {"", false}; | ||
} else { | ||
auto& item = options[i + (screenNum * settingsPerScreen)]; | ||
optionsOnThisScreen[i] = Screens::CheckboxList::Item {item.name, true}; | ||
} | ||
} | ||
} | ||
|
||
SettingWakeUp::SettingWakeUp(Pinetime::Controllers::Settings& settingsController) : settingsController {settingsController} { | ||
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_pad_all(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 10); | ||
lv_obj_set_style_local_pad_inner(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 5); | ||
lv_obj_set_style_local_border_width(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 0); | ||
|
||
lv_obj_set_pos(container1, 10, 35); | ||
lv_obj_set_width(container1, LV_HOR_RES - 20); | ||
lv_obj_set_height(container1, LV_VER_RES - 20); | ||
lv_cont_set_layout(container1, LV_LAYOUT_COLUMN_LEFT); | ||
|
||
lv_obj_t* title = lv_label_create(lv_scr_act(), nullptr); | ||
lv_label_set_text_static(title, "Wake Up"); | ||
lv_label_set_align(title, LV_LABEL_ALIGN_CENTER); | ||
lv_obj_align(title, lv_scr_act(), LV_ALIGN_IN_TOP_MID, 15, 15); | ||
|
||
lv_obj_t* icon = lv_label_create(lv_scr_act(), nullptr); | ||
lv_obj_set_style_local_text_color(icon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_ORANGE); | ||
lv_label_set_text_static(icon, Symbols::eye); | ||
lv_label_set_align(icon, LV_LABEL_ALIGN_CENTER); | ||
lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0); | ||
return std::make_unique<Screens::CheckboxList>( | ||
screenNum, | ||
nScreens, | ||
title, | ||
symbol, | ||
optionsCount, | ||
[this, &settings = settingsController](uint32_t index) { | ||
bool currentState = settingsController.isWakeUpModeOn(options[index].wakeUpMode); | ||
settingsController.setWakeUpMode(options[index].wakeUpMode, !currentState); | ||
}, | ||
optionsOnThisScreen, | ||
false, | ||
[this, &settings = settingsController](uint32_t index) { | ||
bool currentState = settingsController.isWakeUpModeOn(options[index].wakeUpMode); | ||
return currentState; | ||
}); | ||
} | ||
|
||
for (unsigned int i = 0; i < options.size(); i++) { | ||
cbOption[i] = lv_checkbox_create(container1, nullptr); | ||
lv_checkbox_set_text(cbOption[i], options[i].name); | ||
if (settingsController.isWakeUpModeOn(static_cast<Controllers::Settings::WakeUpMode>(i))) { | ||
lv_checkbox_set_checked(cbOption[i], true); | ||
} | ||
cbOption[i]->user_data = this; | ||
lv_obj_set_event_cb(cbOption[i], event_handler); | ||
auto SettingWakeUp::CreateScreenList() const { | ||
std::array<std::function<std::unique_ptr<Screen>()>, nScreens> screens; | ||
for (size_t i = 0; i < screens.size(); i++) { | ||
screens[i] = [this, i]() -> std::unique_ptr<Screen> { | ||
return CreateScreen(i); | ||
}; | ||
} | ||
return screens; | ||
} | ||
|
||
SettingWakeUp::SettingWakeUp(Pinetime::Applications::DisplayApp* app, Pinetime::Controllers::Settings& settingsController) | ||
: settingsController {settingsController}, screens {app, 0, CreateScreenList(), Screens::ScreenListModes::UpDown} { | ||
} | ||
|
||
SettingWakeUp::~SettingWakeUp() { | ||
lv_obj_clean(lv_scr_act()); | ||
settingsController.SaveSettings(); | ||
} | ||
|
||
void SettingWakeUp::UpdateSelected(lv_obj_t* object) { | ||
// Find the index of the checkbox that triggered the event | ||
for (size_t i = 0; i < options.size(); i++) { | ||
if (cbOption[i] == object) { | ||
bool currentState = settingsController.isWakeUpModeOn(options[i].wakeUpMode); | ||
settingsController.setWakeUpMode(options[i].wakeUpMode, !currentState); | ||
break; | ||
} | ||
} | ||
|
||
// Update checkbox according to current wakeup modes. | ||
// 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 (size_t i = 0; i < options.size(); ++i) { | ||
lv_checkbox_set_checked(cbOption[i], modes[i]); | ||
} | ||
bool SettingWakeUp::OnTouchEvent(Pinetime::Applications::TouchEvents event) { | ||
return screens.OnTouchEvent(event); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters