Skip to content

Commit 87d882b

Browse files
committed
Merge branch 'statusBarTimeFormat' of https://github.com/mruss77/InfiniTime into mruss77-statusBarTimeFormat
# Conflicts: # src/components/datetime/DateTimeController.cpp
2 parents d967efa + 947ece0 commit 87d882b

6 files changed

Lines changed: 38 additions & 10 deletions

File tree

src/components/datetime/DateTimeController.cpp

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,9 @@ namespace {
1111
char const* MonthsStringLow[] = {"--", "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"};
1212
}
1313

14+
DateTime::DateTime(Controllers::Settings& settingsController) : settingsController {settingsController} {
15+
}
16+
1417
void DateTime::SetCurrentTime(std::chrono::time_point<std::chrono::system_clock, std::chrono::nanoseconds> t) {
1518
this->currentDateTime = t;
1619
UpdateTime(previousSystickCounter); // Update internal state without updating the time
@@ -120,3 +123,24 @@ const char* DateTime::MonthShortToStringLow(Months month) {
120123
void DateTime::Register(Pinetime::System::SystemTask* systemTask) {
121124
this->systemTask = systemTask;
122125
}
126+
127+
using ClockType = Pinetime::Controllers::Settings::ClockType;
128+
std::string DateTime::FormattedTime() {
129+
// Return time as a string in 12- or 24-hour format
130+
char buff[9];
131+
if (settingsController.GetClockType() == ClockType::H12) {
132+
uint8_t hour12;
133+
const char* amPmStr;
134+
if (hour < 12) {
135+
hour12 = (hour == 0) ? 12 : hour;
136+
amPmStr = "AM";
137+
} else {
138+
hour12 = (hour == 12) ? 12 : hour - 12;
139+
amPmStr = "PM";
140+
}
141+
sprintf(buff, "%i:%02i %s", hour12, minute, amPmStr);
142+
} else {
143+
sprintf(buff, "%02i:%02i", hour, minute);
144+
}
145+
return std::string(buff);
146+
}

src/components/datetime/DateTimeController.h

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,8 @@
22

33
#include <cstdint>
44
#include <chrono>
5+
#include <string>
6+
#include "components/settings/Settings.h"
57

68
namespace Pinetime {
79
namespace System {
@@ -10,6 +12,7 @@ namespace Pinetime {
1012
namespace Controllers {
1113
class DateTime {
1214
public:
15+
DateTime(Controllers::Settings& settingsController);
1316
enum class Days : uint8_t { Unknown, Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday };
1417
enum class Months : uint8_t {
1518
Unknown,
@@ -71,6 +74,7 @@ namespace Pinetime {
7174

7275
void Register(System::SystemTask* systemTask);
7376
void SetCurrentTime(std::chrono::time_point<std::chrono::system_clock, std::chrono::nanoseconds> t);
77+
std::string FormattedTime();
7478

7579
private:
7680
uint16_t year = 0;
@@ -89,6 +93,7 @@ namespace Pinetime {
8993
bool isHourAlreadyNotified = true;
9094
bool isHalfHourAlreadyNotified = true;
9195
System::SystemTask* systemTask = nullptr;
96+
Controllers::Settings& settingsController;
9297
};
9398
}
9499
}

src/components/settings/Settings.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,6 @@
11
#pragma once
22
#include <cstdint>
33
#include <bitset>
4-
#include "components/datetime/DateTimeController.h"
54
#include "components/brightness/BrightnessController.h"
65
#include "components/fs/FS.h"
76

src/displayapp/screens/Tile.cpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ Tile::Tile(uint8_t screenID,
3333

3434
// Time
3535
label_time = lv_label_create(lv_scr_act(), nullptr);
36-
lv_label_set_text_fmt(label_time, "%02i:%02i", dateTimeController.Hours(), dateTimeController.Minutes());
36+
lv_label_set_text(label_time, dateTimeController.FormattedTime().c_str());
3737
lv_label_set_align(label_time, LV_LABEL_ALIGN_CENTER);
3838
lv_obj_align(label_time, nullptr, LV_ALIGN_IN_TOP_LEFT, 0, 0);
3939

@@ -119,7 +119,7 @@ Tile::~Tile() {
119119
}
120120

121121
void Tile::UpdateScreen() {
122-
lv_label_set_text_fmt(label_time, "%02i:%02i", dateTimeController.Hours(), dateTimeController.Minutes());
122+
lv_label_set_text(label_time, dateTimeController.FormattedTime().c_str());
123123
lv_label_set_text(batteryIcon, BatteryIcon::GetBatteryIcon(batteryController.PercentRemaining()));
124124
}
125125

src/displayapp/screens/settings/QuickSettings.cpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,7 @@ QuickSettings::QuickSettings(Pinetime::Applications::DisplayApp* app,
3535

3636
// Time
3737
label_time = lv_label_create(lv_scr_act(), nullptr);
38-
lv_label_set_text_fmt(label_time, "%02i:%02i", dateTimeController.Hours(), dateTimeController.Minutes());
38+
lv_label_set_text(label_time, dateTimeController.FormattedTime().c_str());
3939
lv_label_set_align(label_time, LV_LABEL_ALIGN_CENTER);
4040
lv_obj_align(label_time, lv_scr_act(), LV_ALIGN_IN_TOP_LEFT, 0, 0);
4141

@@ -123,7 +123,7 @@ QuickSettings::~QuickSettings() {
123123
}
124124

125125
void QuickSettings::UpdateScreen() {
126-
lv_label_set_text_fmt(label_time, "%02i:%02i", dateTimeController.Hours(), dateTimeController.Minutes());
126+
lv_label_set_text(label_time, dateTimeController.FormattedTime().c_str());
127127
lv_label_set_text(batteryIcon, BatteryIcon::GetBatteryIcon(batteryController.PercentRemaining()));
128128
}
129129

src/main.cpp

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -101,7 +101,11 @@ Pinetime::Controllers::Ble bleController;
101101
Pinetime::Controllers::HeartRateController heartRateController;
102102
Pinetime::Applications::HeartRateTask heartRateApp(heartRateSensor, heartRateController);
103103

104-
Pinetime::Controllers::DateTime dateTimeController;
104+
Pinetime::Controllers::FS fs {spiNorFlash};
105+
Pinetime::Controllers::Settings settingsController {fs};
106+
Pinetime::Controllers::MotorController motorController {};
107+
108+
Pinetime::Controllers::DateTime dateTimeController {settingsController};
105109
Pinetime::Drivers::Watchdog watchdog;
106110
Pinetime::Drivers::WatchdogView watchdogView(watchdog);
107111
Pinetime::Controllers::NotificationManager notificationManager;
@@ -111,10 +115,6 @@ Pinetime::Controllers::AlarmController alarmController {dateTimeController};
111115
Pinetime::Controllers::TouchHandler touchHandler(touchPanel, lvgl);
112116
Pinetime::Controllers::ButtonHandler buttonHandler;
113117

114-
Pinetime::Controllers::FS fs {spiNorFlash};
115-
Pinetime::Controllers::Settings settingsController {fs};
116-
Pinetime::Controllers::MotorController motorController {};
117-
118118
Pinetime::Applications::DisplayApp displayApp(lcd,
119119
lvgl,
120120
touchPanel,

0 commit comments

Comments
 (0)