summaryrefslogtreecommitdiff
path: root/src/main.cpp
diff options
context:
space:
mode:
authorJF <jf@codingfield.com>2019-12-28 14:34:50 +0100
committerJF <jf@codingfield.com>2019-12-28 14:34:50 +0100
commitb744b96622e684a2aa29c358e124f288ba3cf9cc (patch)
treebd3971fc9ec41b72089b1e7698c6520e3ff548b2 /src/main.cpp
parent92985eb98be0cc1c6b3951172f8bbaca456bb608 (diff)
Add DateTimeController to manage the time.
Use messages in message queues to refresh the UI
Diffstat (limited to 'src/main.cpp')
-rw-r--r--src/main.cpp23
1 files changed, 18 insertions, 5 deletions
diff --git a/src/main.cpp b/src/main.cpp
index 396935b0..6463415a 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -10,6 +10,8 @@
#include <hal/nrf_rtc.h>
#include <timers.h>
#include <libraries/log/nrf_log.h>
+#include <ble/ble_services/ble_cts_c/ble_cts_c.h>
+#include <Components/DateTime/DateTimeController.h>
#include "BLE/BleManager.h"
#include "Components/Battery/BatteryController.h"
#include "Components/Ble/BleController.h"
@@ -28,6 +30,7 @@ bool isSleeping = false;
TimerHandle_t debounceTimer;
Pinetime::Controllers::Battery batteryController;
Pinetime::Controllers::Ble bleController;
+Pinetime::Controllers::DateTime dateTimeController;
extern "C" {
void vApplicationIdleHook() {
@@ -51,6 +54,7 @@ void DebounceTimerCallback(TimerHandle_t xTimer) {
displayApp->PushMessage(Pinetime::Applications::DisplayApp::Messages::GoToRunning);
isSleeping = false;
batteryController.Update();
+ displayApp->PushMessage(Pinetime::Applications::DisplayApp::Messages::UpdateBatteryLevel);
}
else {
displayApp->PushMessage(Pinetime::Applications::DisplayApp::Messages::GoToSleep);
@@ -66,6 +70,7 @@ void SystemTask(void *) {
batteryController.Init();
batteryController.Update();
+ displayApp->PushMessage(Pinetime::Applications::DisplayApp::Messages::UpdateBatteryLevel);
debounceTimer = xTimerCreate ("debounceTimer", 200, pdFALSE, (void *) 0, DebounceTimerCallback);
@@ -81,18 +86,26 @@ void SystemTask(void *) {
pinConfig.pull = (nrf_gpio_pin_pull_t)GPIO_PIN_CNF_PULL_Pulldown;
nrfx_gpiote_in_init(13, &pinConfig, nrfx_gpiote_evt_handler);
-
-
vTaskSuspend(nullptr);
}
-void OnNewTime(uint8_t minutes, uint8_t hours) {
+void OnNewTime(current_time_char_t* currentTime) {
bleController.Connect();
- displayApp->SetTime(minutes, hours);
+ displayApp->PushMessage(Pinetime::Applications::DisplayApp::Messages::UpdateBleConnection);
+
+ auto dayOfWeek = currentTime->exact_time_256.day_date_time.day_of_week;
+ auto year = currentTime->exact_time_256.day_date_time.date_time.year;
+ auto month = currentTime->exact_time_256.day_date_time.date_time.month;
+ auto day = currentTime->exact_time_256.day_date_time.date_time.day;
+ auto hour = currentTime->exact_time_256.day_date_time.date_time.hours;
+ auto minute = currentTime->exact_time_256.day_date_time.date_time.minutes;
+ auto second = currentTime->exact_time_256.day_date_time.date_time.seconds;
+ dateTimeController.UpdateTime(year, static_cast<Pinetime::Controllers::DateTime::Months >(month), day, static_cast<Pinetime::Controllers::DateTime::Days>(dayOfWeek), hour, minute, second);
+ displayApp->PushMessage(Pinetime::Applications::DisplayApp::Messages::UpdateDateTime);
}
int main(void) {
- displayApp.reset(new Pinetime::Applications::DisplayApp(batteryController, bleController));
+ displayApp.reset(new Pinetime::Applications::DisplayApp(batteryController, bleController, dateTimeController));
logger.Init();
nrf_drv_clock_init();