diff options
Diffstat (limited to 'src/displayapp/screens')
| -rw-r--r-- | src/displayapp/screens/BatteryIcon.cpp | 14 | ||||
| -rw-r--r-- | src/displayapp/screens/BatteryIcon.h | 2 | ||||
| -rw-r--r-- | src/displayapp/screens/WatchFaceAnalog.cpp | 1 | ||||
| -rw-r--r-- | src/displayapp/screens/WatchFaceCasioStyleG7710.cpp | 1 | ||||
| -rw-r--r-- | src/displayapp/screens/WatchFacePineTimeStyle.cpp | 1 |
5 files changed, 19 insertions, 0 deletions
diff --git a/src/displayapp/screens/BatteryIcon.cpp b/src/displayapp/screens/BatteryIcon.cpp index 2fe7c251..6194807d 100644 --- a/src/displayapp/screens/BatteryIcon.cpp +++ b/src/displayapp/screens/BatteryIcon.cpp @@ -2,9 +2,12 @@ #include <cstdint> #include "displayapp/screens/Symbols.h" #include "displayapp/icons/battery/batteryicon.c" +#include "displayapp/InfiniTimeTheme.h" using namespace Pinetime::Applications::Screens; +BatteryIcon::BatteryIcon(bool colorOnLowBattery) : colorOnLowBattery {colorOnLowBattery} {}; + void BatteryIcon::Create(lv_obj_t* parent) { batteryImg = lv_img_create(parent, nullptr); lv_img_set_src(batteryImg, &batteryicon); @@ -23,6 +26,17 @@ lv_obj_t* BatteryIcon::GetObject() { void BatteryIcon::SetBatteryPercentage(uint8_t percentage) { lv_obj_set_height(batteryJuice, percentage * 14 / 100); lv_obj_realign(batteryJuice); + if (colorOnLowBattery) { + static constexpr int lowBatteryThreshold = 15; + static constexpr int criticalBatteryThreshold = 5; + if (percentage > lowBatteryThreshold) { + SetColor(LV_COLOR_WHITE); + } else if (percentage > criticalBatteryThreshold) { + SetColor(LV_COLOR_ORANGE); + } else { + SetColor(Colors::deepOrange); + } + } } void BatteryIcon::SetColor(lv_color_t color) { diff --git a/src/displayapp/screens/BatteryIcon.h b/src/displayapp/screens/BatteryIcon.h index 45d8f0ef..19fea967 100644 --- a/src/displayapp/screens/BatteryIcon.h +++ b/src/displayapp/screens/BatteryIcon.h @@ -7,6 +7,7 @@ namespace Pinetime { namespace Screens { class BatteryIcon { public: + explicit BatteryIcon(bool colorOnLowBattery); void Create(lv_obj_t* parent); void SetColor(lv_color_t); @@ -19,6 +20,7 @@ namespace Pinetime { private: lv_obj_t* batteryImg; lv_obj_t* batteryJuice; + bool colorOnLowBattery = false; }; } } diff --git a/src/displayapp/screens/WatchFaceAnalog.cpp b/src/displayapp/screens/WatchFaceAnalog.cpp index 34b50655..ad66be15 100644 --- a/src/displayapp/screens/WatchFaceAnalog.cpp +++ b/src/displayapp/screens/WatchFaceAnalog.cpp @@ -49,6 +49,7 @@ WatchFaceAnalog::WatchFaceAnalog(Controllers::DateTime& dateTimeController, Controllers::NotificationManager& notificationManager, Controllers::Settings& settingsController) : currentDateTime {{}}, + batteryIcon(true), dateTimeController {dateTimeController}, batteryController {batteryController}, bleController {bleController}, diff --git a/src/displayapp/screens/WatchFaceCasioStyleG7710.cpp b/src/displayapp/screens/WatchFaceCasioStyleG7710.cpp index 0bfb7193..ca37c8fc 100644 --- a/src/displayapp/screens/WatchFaceCasioStyleG7710.cpp +++ b/src/displayapp/screens/WatchFaceCasioStyleG7710.cpp @@ -23,6 +23,7 @@ WatchFaceCasioStyleG7710::WatchFaceCasioStyleG7710(Controllers::DateTime& dateTi Controllers::MotionController& motionController, Controllers::FS& filesystem) : currentDateTime {{}}, + batteryIcon(false), dateTimeController {dateTimeController}, batteryController {batteryController}, bleController {bleController}, diff --git a/src/displayapp/screens/WatchFacePineTimeStyle.cpp b/src/displayapp/screens/WatchFacePineTimeStyle.cpp index 19841c15..d1eca286 100644 --- a/src/displayapp/screens/WatchFacePineTimeStyle.cpp +++ b/src/displayapp/screens/WatchFacePineTimeStyle.cpp @@ -50,6 +50,7 @@ WatchFacePineTimeStyle::WatchFacePineTimeStyle(Controllers::DateTime& dateTimeCo Controllers::Settings& settingsController, Controllers::MotionController& motionController) : currentDateTime {{}}, + batteryIcon(false), dateTimeController {dateTimeController}, batteryController {batteryController}, bleController {bleController}, |
