Merge pull request #1 from Riksu9000/pts-settings-fix
Close customizer menu with button in PTS
This commit is contained in:
commit
2fa63c7f37
5 changed files with 66 additions and 41 deletions
|
@ -249,10 +249,10 @@ void DisplayApp::Refresh() {
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
case Messages::ButtonPushed:
|
case Messages::ButtonPushed:
|
||||||
|
if (!currentScreen->OnButtonPushed()) {
|
||||||
if (currentApp == Apps::Clock) {
|
if (currentApp == Apps::Clock) {
|
||||||
PushMessageToSystemTask(System::Messages::GoToSleep);
|
PushMessageToSystemTask(System::Messages::GoToSleep);
|
||||||
} else {
|
} else {
|
||||||
if (!currentScreen->OnButtonPushed()) {
|
|
||||||
LoadApp(returnToApp, returnDirection);
|
LoadApp(returnToApp, returnDirection);
|
||||||
brightnessController.Set(settingsController.GetBrightness());
|
brightnessController.Set(settingsController.GetBrightness());
|
||||||
brightnessController.Backup();
|
brightnessController.Backup();
|
||||||
|
|
|
@ -54,6 +54,10 @@ bool Clock::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
|
||||||
return screen->OnTouchEvent(event);
|
return screen->OnTouchEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Clock::OnButtonPushed() {
|
||||||
|
return screen->OnButtonPushed();
|
||||||
|
}
|
||||||
|
|
||||||
std::unique_ptr<Screen> Clock::WatchFaceDigitalScreen() {
|
std::unique_ptr<Screen> Clock::WatchFaceDigitalScreen() {
|
||||||
return std::make_unique<Screens::WatchFaceDigital>(app,
|
return std::make_unique<Screens::WatchFaceDigital>(app,
|
||||||
dateTimeController,
|
dateTimeController,
|
||||||
|
|
|
@ -32,6 +32,7 @@ namespace Pinetime {
|
||||||
~Clock() override;
|
~Clock() override;
|
||||||
|
|
||||||
bool OnTouchEvent(TouchEvents event) override;
|
bool OnTouchEvent(TouchEvents event) override;
|
||||||
|
bool OnButtonPushed() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Controllers::DateTime& dateTimeController;
|
Controllers::DateTime& dateTimeController;
|
||||||
|
|
|
@ -38,8 +38,8 @@
|
||||||
using namespace Pinetime::Applications::Screens;
|
using namespace Pinetime::Applications::Screens;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
static void event_handler(lv_obj_t* obj, lv_event_t event) {
|
void event_handler(lv_obj_t* obj, lv_event_t event) {
|
||||||
PineTimeStyle* screen = static_cast<PineTimeStyle*>(obj->user_data);
|
auto* screen = static_cast<PineTimeStyle*>(obj->user_data);
|
||||||
screen->UpdateSelected(obj, event);
|
screen->UpdateSelected(obj, event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -305,7 +305,7 @@ PineTimeStyle::~PineTimeStyle() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PineTimeStyle::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
|
bool PineTimeStyle::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
|
||||||
if ((event == Pinetime::Applications::TouchEvents::LongTap) && (lv_obj_get_hidden(btnRandom) == true)) {
|
if ((event == Pinetime::Applications::TouchEvents::LongTap) && lv_obj_get_hidden(btnRandom)) {
|
||||||
lv_obj_set_hidden(btnSet, false);
|
lv_obj_set_hidden(btnSet, false);
|
||||||
savedTick = lv_tick_get();
|
savedTick = lv_tick_get();
|
||||||
return true;
|
return true;
|
||||||
|
@ -316,6 +316,27 @@ bool PineTimeStyle::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PineTimeStyle::CloseMenu() {
|
||||||
|
settingsController.SaveSettings();
|
||||||
|
lv_obj_set_hidden(btnNextTime, true);
|
||||||
|
lv_obj_set_hidden(btnPrevTime, true);
|
||||||
|
lv_obj_set_hidden(btnNextBar, true);
|
||||||
|
lv_obj_set_hidden(btnPrevBar, true);
|
||||||
|
lv_obj_set_hidden(btnNextBG, true);
|
||||||
|
lv_obj_set_hidden(btnPrevBG, true);
|
||||||
|
lv_obj_set_hidden(btnReset, true);
|
||||||
|
lv_obj_set_hidden(btnRandom, true);
|
||||||
|
lv_obj_set_hidden(btnClose, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool PineTimeStyle::OnButtonPushed() {
|
||||||
|
if (!lv_obj_get_hidden(btnClose)) {
|
||||||
|
CloseMenu();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void PineTimeStyle::SetBatteryIcon() {
|
void PineTimeStyle::SetBatteryIcon() {
|
||||||
auto batteryPercent = batteryPercentRemaining.Get();
|
auto batteryPercent = batteryPercentRemaining.Get();
|
||||||
lv_label_set_text(batteryIcon, BatteryIcon::GetBatteryIcon(batteryPercent));
|
lv_label_set_text(batteryIcon, BatteryIcon::GetBatteryIcon(batteryPercent));
|
||||||
|
@ -426,7 +447,7 @@ void PineTimeStyle::Refresh() {
|
||||||
lv_obj_set_style_local_scale_grad_color(stepGauge, LV_GAUGE_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_WHITE);
|
lv_obj_set_style_local_scale_grad_color(stepGauge, LV_GAUGE_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_WHITE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (lv_obj_get_hidden(btnSet) == false) {
|
if (!lv_obj_get_hidden(btnSet)) {
|
||||||
if ((savedTick > 0) && (lv_tick_get() - savedTick > 3000)) {
|
if ((savedTick > 0) && (lv_tick_get() - savedTick > 3000)) {
|
||||||
lv_obj_set_hidden(btnSet, true);
|
lv_obj_set_hidden(btnSet, true);
|
||||||
savedTick = 0;
|
savedTick = 0;
|
||||||
|
@ -442,8 +463,9 @@ void PineTimeStyle::UpdateSelected(lv_obj_t* object, lv_event_t event) {
|
||||||
if (event == LV_EVENT_CLICKED) {
|
if (event == LV_EVENT_CLICKED) {
|
||||||
if (object == btnNextTime) {
|
if (object == btnNextTime) {
|
||||||
valueTime = GetNext(valueTime);
|
valueTime = GetNext(valueTime);
|
||||||
if(valueTime == valueBG)
|
if (valueTime == valueBG) {
|
||||||
valueTime = GetNext(valueTime);
|
valueTime = GetNext(valueTime);
|
||||||
|
}
|
||||||
settingsController.SetPTSColorTime(valueTime);
|
settingsController.SetPTSColorTime(valueTime);
|
||||||
lv_obj_set_style_local_text_color(timeDD1, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
lv_obj_set_style_local_text_color(timeDD1, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
||||||
lv_obj_set_style_local_text_color(timeDD2, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
lv_obj_set_style_local_text_color(timeDD2, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
||||||
|
@ -451,8 +473,9 @@ void PineTimeStyle::UpdateSelected(lv_obj_t* object, lv_event_t event) {
|
||||||
}
|
}
|
||||||
if (object == btnPrevTime) {
|
if (object == btnPrevTime) {
|
||||||
valueTime = GetPrevious(valueTime);
|
valueTime = GetPrevious(valueTime);
|
||||||
if(valueTime == valueBG)
|
if (valueTime == valueBG) {
|
||||||
valueTime = GetPrevious(valueTime);
|
valueTime = GetPrevious(valueTime);
|
||||||
|
}
|
||||||
settingsController.SetPTSColorTime(valueTime);
|
settingsController.SetPTSColorTime(valueTime);
|
||||||
lv_obj_set_style_local_text_color(timeDD1, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
lv_obj_set_style_local_text_color(timeDD1, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
||||||
lv_obj_set_style_local_text_color(timeDD2, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
lv_obj_set_style_local_text_color(timeDD2, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Convert(valueTime));
|
||||||
|
@ -460,8 +483,9 @@ void PineTimeStyle::UpdateSelected(lv_obj_t* object, lv_event_t event) {
|
||||||
}
|
}
|
||||||
if (object == btnNextBar) {
|
if (object == btnNextBar) {
|
||||||
valueBar = GetNext(valueBar);
|
valueBar = GetNext(valueBar);
|
||||||
if(valueBar == Controllers::Settings::Colors::Black)
|
if (valueBar == Controllers::Settings::Colors::Black) {
|
||||||
valueBar = GetNext(valueBar);
|
valueBar = GetNext(valueBar);
|
||||||
|
}
|
||||||
if (valueBar == Controllers::Settings::Colors::White) {
|
if (valueBar == Controllers::Settings::Colors::White) {
|
||||||
needle_colors[0] = LV_COLOR_BLACK;
|
needle_colors[0] = LV_COLOR_BLACK;
|
||||||
} else {
|
} else {
|
||||||
|
@ -472,8 +496,9 @@ void PineTimeStyle::UpdateSelected(lv_obj_t* object, lv_event_t event) {
|
||||||
}
|
}
|
||||||
if (object == btnPrevBar) {
|
if (object == btnPrevBar) {
|
||||||
valueBar = GetPrevious(valueBar);
|
valueBar = GetPrevious(valueBar);
|
||||||
if(valueBar == Controllers::Settings::Colors::Black)
|
if (valueBar == Controllers::Settings::Colors::Black) {
|
||||||
valueBar = GetPrevious(valueBar);
|
valueBar = GetPrevious(valueBar);
|
||||||
|
}
|
||||||
if (valueBar == Controllers::Settings::Colors::White) {
|
if (valueBar == Controllers::Settings::Colors::White) {
|
||||||
needle_colors[0] = LV_COLOR_BLACK;
|
needle_colors[0] = LV_COLOR_BLACK;
|
||||||
} else {
|
} else {
|
||||||
|
@ -484,15 +509,17 @@ void PineTimeStyle::UpdateSelected(lv_obj_t* object, lv_event_t event) {
|
||||||
}
|
}
|
||||||
if (object == btnNextBG) {
|
if (object == btnNextBG) {
|
||||||
valueBG = GetNext(valueBG);
|
valueBG = GetNext(valueBG);
|
||||||
if(valueBG == valueTime)
|
if (valueBG == valueTime) {
|
||||||
valueBG = GetNext(valueBG);
|
valueBG = GetNext(valueBG);
|
||||||
|
}
|
||||||
settingsController.SetPTSColorBG(valueBG);
|
settingsController.SetPTSColorBG(valueBG);
|
||||||
lv_obj_set_style_local_bg_color(timebar, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, Convert(valueBG));
|
lv_obj_set_style_local_bg_color(timebar, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, Convert(valueBG));
|
||||||
}
|
}
|
||||||
if (object == btnPrevBG) {
|
if (object == btnPrevBG) {
|
||||||
valueBG = GetPrevious(valueBG);
|
valueBG = GetPrevious(valueBG);
|
||||||
if(valueBG == valueTime)
|
if (valueBG == valueTime) {
|
||||||
valueBG = GetPrevious(valueBG);
|
valueBG = GetPrevious(valueBG);
|
||||||
|
}
|
||||||
settingsController.SetPTSColorBG(valueBG);
|
settingsController.SetPTSColorBG(valueBG);
|
||||||
lv_obj_set_style_local_bg_color(timebar, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, Convert(valueBG));
|
lv_obj_set_style_local_bg_color(timebar, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, Convert(valueBG));
|
||||||
}
|
}
|
||||||
|
@ -532,16 +559,7 @@ void PineTimeStyle::UpdateSelected(lv_obj_t* object, lv_event_t event) {
|
||||||
lv_obj_set_style_local_bg_color(timebar, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, Convert(valueBG));
|
lv_obj_set_style_local_bg_color(timebar, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, Convert(valueBG));
|
||||||
}
|
}
|
||||||
if (object == btnClose) {
|
if (object == btnClose) {
|
||||||
settingsController.SaveSettings();
|
CloseMenu();
|
||||||
lv_obj_set_hidden(btnNextTime, true);
|
|
||||||
lv_obj_set_hidden(btnPrevTime, true);
|
|
||||||
lv_obj_set_hidden(btnNextBar, true);
|
|
||||||
lv_obj_set_hidden(btnPrevBar, true);
|
|
||||||
lv_obj_set_hidden(btnNextBG, true);
|
|
||||||
lv_obj_set_hidden(btnPrevBG, true);
|
|
||||||
lv_obj_set_hidden(btnReset, true);
|
|
||||||
lv_obj_set_hidden(btnRandom, true);
|
|
||||||
lv_obj_set_hidden(btnClose, true);
|
|
||||||
}
|
}
|
||||||
if (object == btnSet) {
|
if (object == btnSet) {
|
||||||
lv_obj_set_hidden(btnSet, true);
|
lv_obj_set_hidden(btnSet, true);
|
||||||
|
|
|
@ -31,6 +31,7 @@ namespace Pinetime {
|
||||||
~PineTimeStyle() override;
|
~PineTimeStyle() override;
|
||||||
|
|
||||||
bool OnTouchEvent(TouchEvents event) override;
|
bool OnTouchEvent(TouchEvents event) override;
|
||||||
|
bool OnButtonPushed() override;
|
||||||
|
|
||||||
void Refresh() override;
|
void Refresh() override;
|
||||||
|
|
||||||
|
@ -53,8 +54,8 @@ namespace Pinetime {
|
||||||
DirtyValue<uint32_t> stepCount {};
|
DirtyValue<uint32_t> stepCount {};
|
||||||
DirtyValue<bool> notificationState {};
|
DirtyValue<bool> notificationState {};
|
||||||
|
|
||||||
Pinetime::Controllers::Settings::Colors GetNext(Controllers::Settings::Colors color);
|
static Pinetime::Controllers::Settings::Colors GetNext(Controllers::Settings::Colors color);
|
||||||
Pinetime::Controllers::Settings::Colors GetPrevious(Controllers::Settings::Colors color);
|
static Pinetime::Controllers::Settings::Colors GetPrevious(Controllers::Settings::Colors color);
|
||||||
|
|
||||||
lv_obj_t* btnNextTime;
|
lv_obj_t* btnNextTime;
|
||||||
lv_obj_t* btnPrevTime;
|
lv_obj_t* btnPrevTime;
|
||||||
|
@ -96,6 +97,7 @@ namespace Pinetime {
|
||||||
Controllers::MotionController& motionController;
|
Controllers::MotionController& motionController;
|
||||||
|
|
||||||
void SetBatteryIcon();
|
void SetBatteryIcon();
|
||||||
|
void CloseMenu();
|
||||||
|
|
||||||
lv_task_t* taskRefresh;
|
lv_task_t* taskRefresh;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue