Implement charging battery animation
This commit is contained in:
parent
b5bf6c51a4
commit
cb2131ec2c
2 changed files with 18 additions and 5 deletions
|
@ -145,7 +145,7 @@ WatchFaceInfineat::WatchFaceInfineat(DisplayApp* app,
|
||||||
lv_style_set_line_width(&lineBatteryStyle, LV_STATE_DEFAULT, 24);
|
lv_style_set_line_width(&lineBatteryStyle, LV_STATE_DEFAULT, 24);
|
||||||
lv_style_set_line_color(&lineBatteryStyle, LV_STATE_DEFAULT,
|
lv_style_set_line_color(&lineBatteryStyle, LV_STATE_DEFAULT,
|
||||||
lv_color_hex(infineatColors.orange[settingsController.GetInfineatColorIndex()*nLines + 4]));
|
lv_color_hex(infineatColors.orange[settingsController.GetInfineatColorIndex()*nLines + 4]));
|
||||||
lv_style_set_line_opa(&lineBatteryStyle, LV_STATE_DEFAULT, LV_OPA_80);
|
lv_style_set_line_opa(&lineBatteryStyle, LV_STATE_DEFAULT, 190);
|
||||||
lv_obj_add_style(lineBattery, LV_LINE_PART_MAIN, &lineBatteryStyle);
|
lv_obj_add_style(lineBattery, LV_LINE_PART_MAIN, &lineBatteryStyle);
|
||||||
lineBatteryPoints[0] = {27, 105};
|
lineBatteryPoints[0] = {27, 105};
|
||||||
lineBatteryPoints[1] = {27, 106};
|
lineBatteryPoints[1] = {27, 106};
|
||||||
|
@ -484,9 +484,20 @@ void WatchFaceInfineat::Refresh() {
|
||||||
}
|
}
|
||||||
|
|
||||||
batteryPercentRemaining = batteryController.PercentRemaining();
|
batteryPercentRemaining = batteryController.PercentRemaining();
|
||||||
if (batteryPercentRemaining.IsUpdated()) {
|
isCharging = batteryController.IsCharging();
|
||||||
auto batteryPercent = batteryPercentRemaining.Get();
|
// We store if battery and charging are updated before calling Get(),
|
||||||
SetBatteryLevel(batteryPercent);
|
// since Get() sets isUpdated to false.
|
||||||
|
bool isBatteryUpdated = batteryPercentRemaining.IsUpdated();
|
||||||
|
bool isChargingUpdated = isCharging.IsUpdated();
|
||||||
|
if (isCharging.Get()) { // Charging battery animation
|
||||||
|
chargingBatteryPercent += 1;
|
||||||
|
if (chargingBatteryPercent > 100) {
|
||||||
|
chargingBatteryPercent = batteryPercentRemaining.Get();
|
||||||
|
}
|
||||||
|
SetBatteryLevel(chargingBatteryPercent);
|
||||||
|
} else if (isChargingUpdated || isBatteryUpdated) {
|
||||||
|
chargingBatteryPercent = batteryPercentRemaining.Get();
|
||||||
|
SetBatteryLevel(chargingBatteryPercent);
|
||||||
}
|
}
|
||||||
|
|
||||||
bleState = bleController.IsConnected();
|
bleState = bleController.IsConnected();
|
||||||
|
|
|
@ -46,9 +46,11 @@ namespace Pinetime {
|
||||||
Pinetime::Controllers::DateTime::Days currentDayOfWeek = Pinetime::Controllers::DateTime::Days::Unknown;
|
Pinetime::Controllers::DateTime::Days currentDayOfWeek = Pinetime::Controllers::DateTime::Days::Unknown;
|
||||||
uint8_t currentDay = 0;
|
uint8_t currentDay = 0;
|
||||||
uint32_t savedTick = 0;
|
uint32_t savedTick = 0;
|
||||||
|
uint8_t chargingBatteryPercent = 101; // not a mistake ;)
|
||||||
|
|
||||||
|
|
||||||
DirtyValue<uint8_t> batteryPercentRemaining {};
|
DirtyValue<uint8_t> batteryPercentRemaining {};
|
||||||
DirtyValue<bool> powerPresent {};
|
DirtyValue<bool> isCharging {};
|
||||||
DirtyValue<bool> bleState {};
|
DirtyValue<bool> bleState {};
|
||||||
DirtyValue<bool> bleRadioEnabled {};
|
DirtyValue<bool> bleRadioEnabled {};
|
||||||
DirtyValue<std::chrono::time_point<std::chrono::system_clock, std::chrono::nanoseconds>> currentDateTime {};
|
DirtyValue<std::chrono::time_point<std::chrono::system_clock, std::chrono::nanoseconds>> currentDateTime {};
|
||||||
|
|
Loading…
Reference in a new issue