aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorSteve Amor <steveamor@users.noreply.github.com>2025-07-19 07:20:07 +0100
committerJF <JF002@users.noreply.github.com>2025-11-04 21:46:23 +0100
commit04afd22943cf4d6a826e09cf5fd246886ee7cacf (patch)
tree63b7650f4685228db87bf3e326ffd8ecf18a4a84 /src
parent101f9626e3e42c8edc180eccda2549b6fbba491f (diff)
Refactor pageindicator
Diffstat (limited to 'src')
-rw-r--r--src/displayapp/screens/Music.cpp4
-rw-r--r--src/displayapp/widgets/PageIndicator.cpp12
-rw-r--r--src/displayapp/widgets/PageIndicator.h3
3 files changed, 7 insertions, 12 deletions
diff --git a/src/displayapp/screens/Music.cpp b/src/displayapp/screens/Music.cpp
index 89de86a7..e1441460 100644
--- a/src/displayapp/screens/Music.cpp
+++ b/src/displayapp/screens/Music.cpp
@@ -257,7 +257,7 @@ bool Music::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
lv_obj_set_hidden(btnVolUp, false);
lv_obj_set_hidden(btnNext, true);
lv_obj_set_hidden(btnPrev, true);
- pageIndicator.SetCurrentScreen(1);
+ pageIndicator.SetPageIndicatorPosition(1);
return true;
}
case TouchEvents::SwipeDown: {
@@ -266,7 +266,7 @@ bool Music::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
lv_obj_set_hidden(btnPrev, false);
lv_obj_set_hidden(btnVolDown, true);
lv_obj_set_hidden(btnVolUp, true);
- pageIndicator.SetCurrentScreen(0);
+ pageIndicator.SetPageIndicatorPosition(0);
return true;
}
return false;
diff --git a/src/displayapp/widgets/PageIndicator.cpp b/src/displayapp/widgets/PageIndicator.cpp
index 5d9815da..cee979f2 100644
--- a/src/displayapp/widgets/PageIndicator.cpp
+++ b/src/displayapp/widgets/PageIndicator.cpp
@@ -16,6 +16,10 @@ void PageIndicator::Create() {
lv_obj_set_style_local_line_width(pageIndicatorBase, LV_LINE_PART_MAIN, LV_STATE_DEFAULT, 3);
lv_obj_set_style_local_line_color(pageIndicatorBase, LV_LINE_PART_MAIN, LV_STATE_DEFAULT, Colors::bgDark);
lv_line_set_points(pageIndicatorBase, pageIndicatorBasePoints, 2);
+
+ pageIndicator = lv_line_create(lv_scr_act(), nullptr);
+ lv_obj_set_style_local_line_width(pageIndicator, LV_LINE_PART_MAIN, LV_STATE_DEFAULT, 3);
+ lv_obj_set_style_local_line_color(pageIndicator, LV_LINE_PART_MAIN, LV_STATE_DEFAULT, Colors::lightGray);
SetPageIndicatorPosition(nCurrentScreen);
}
@@ -28,13 +32,5 @@ void PageIndicator::SetPageIndicatorPosition(uint8_t position) {
pageIndicatorPoints[1].x = LV_HOR_RES - 1;
pageIndicatorPoints[1].y = indicatorPos + indicatorSize;
- pageIndicator = lv_line_create(lv_scr_act(), nullptr);
- lv_obj_set_style_local_line_width(pageIndicator, LV_LINE_PART_MAIN, LV_STATE_DEFAULT, 3);
- lv_obj_set_style_local_line_color(pageIndicator, LV_LINE_PART_MAIN, LV_STATE_DEFAULT, Colors::lightGray);
lv_line_set_points(pageIndicator, pageIndicatorPoints, 2);
}
-
-void PageIndicator::SetCurrentScreen(uint8_t nScreen) {
- lv_obj_del(pageIndicator);
- SetPageIndicatorPosition(nScreen);
-}
diff --git a/src/displayapp/widgets/PageIndicator.h b/src/displayapp/widgets/PageIndicator.h
index b9d3117b..b9aaffe4 100644
--- a/src/displayapp/widgets/PageIndicator.h
+++ b/src/displayapp/widgets/PageIndicator.h
@@ -8,10 +8,9 @@ namespace Pinetime {
public:
PageIndicator(uint8_t nCurrentScreen, uint8_t nScreens);
void Create();
- void SetCurrentScreen(uint8_t nScreen);
+ void SetPageIndicatorPosition(uint8_t position);
private:
- void SetPageIndicatorPosition(uint8_t position);
uint8_t nCurrentScreen;
uint8_t nScreens;