Optimize SettingWakeUp
This commit is contained in:
		
							parent
							
								
									9c5b1437ec
								
							
						
					
					
						commit
						99b5b49993
					
				@ -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;
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -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()];
 | 
				
			||||||
      };
 | 
					      };
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user