From 79da9b082463c824b63f8612ff352b2fedc6c106 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jean-Fran=C3=A7ois=20Milants?= Date: Sat, 9 Dec 2023 21:05:50 +0100 Subject: [PATCH] SimpleWeather service : new weather implementation Fix recovery firmware and code formatting. --- src/components/ble/SimpleWeatherService.cpp | 71 ++++++++++--------- src/components/ble/SimpleWeatherService.h | 38 ++++++---- src/displayapp/DisplayAppRecovery.cpp | 2 +- src/displayapp/DisplayAppRecovery.h | 4 +- .../screens/WatchFacePineTimeStyle.cpp | 40 ++++++++--- 5 files changed, 93 insertions(+), 62 deletions(-) diff --git a/src/components/ble/SimpleWeatherService.cpp b/src/components/ble/SimpleWeatherService.cpp index fa0ce1987a..729e9352a0 100644 --- a/src/components/ble/SimpleWeatherService.cpp +++ b/src/components/ble/SimpleWeatherService.cpp @@ -22,45 +22,45 @@ using namespace Pinetime::Controllers; namespace { - enum class MessageType { - CurrentWeather, - Forecast, - Unknown - }; + enum class MessageType { CurrentWeather, Forecast, Unknown }; SimpleWeatherService::CurrentWeather CreateCurrentWeather(const uint8_t* dataBuffer) { char cityName[33]; std::memcpy(&cityName[0], &dataBuffer[13], 32); cityName[32] = '\0'; - return SimpleWeatherService::CurrentWeather{dataBuffer[2] + (dataBuffer[3] << 8) + (dataBuffer[4] << 16) + (dataBuffer[5] << 24) + - ((uint64_t) dataBuffer[6] << 32) + ((uint64_t) dataBuffer[7] << 40) + ((uint64_t) dataBuffer[8] << 48) + - ((uint64_t) dataBuffer[9] << 54), - dataBuffer[10], - dataBuffer[11], - dataBuffer[12], - dataBuffer[13 + 32], - cityName}; + return SimpleWeatherService::CurrentWeather {dataBuffer[2] + (dataBuffer[3] << 8) + (dataBuffer[4] << 16) + (dataBuffer[5] << 24) + + ((uint64_t) dataBuffer[6] << 32) + ((uint64_t) dataBuffer[7] << 40) + + ((uint64_t) dataBuffer[8] << 48) + ((uint64_t) dataBuffer[9] << 54), + dataBuffer[10], + dataBuffer[11], + dataBuffer[12], + dataBuffer[13 + 32], + cityName}; } SimpleWeatherService::Forecast CreateForecast(const uint8_t* dataBuffer) { uint64_t timestamp = static_cast(dataBuffer[2] + (dataBuffer[3] << 8) + (dataBuffer[4] << 16) + (dataBuffer[5] << 24) + - ((uint64_t) dataBuffer[6] << 32) + ((uint64_t) dataBuffer[7] << 40) + ((uint64_t) dataBuffer[8] << 48) + - ((uint64_t) dataBuffer[9] << 54)); + ((uint64_t) dataBuffer[6] << 32) + ((uint64_t) dataBuffer[7] << 40) + + ((uint64_t) dataBuffer[8] << 48) + ((uint64_t) dataBuffer[9] << 54)); uint8_t nbDays = dataBuffer[10]; std::array days; for (int i = 0; i < nbDays; i++) { - days[i] = SimpleWeatherService::Forecast::Day {dataBuffer[11 + (i * 3)], - dataBuffer[12 + (i * 3)], - dataBuffer[13 + (i * 3)]}; + days[i] = SimpleWeatherService::Forecast::Day {dataBuffer[11 + (i * 3)], dataBuffer[12 + (i * 3)], dataBuffer[13 + (i * 3)]}; } return SimpleWeatherService::Forecast {timestamp, nbDays, days}; } MessageType GetMessageType(const uint8_t* dataBuffer) { - switch(dataBuffer[0]) { - case 0: return MessageType::CurrentWeather; break; - case 1: return MessageType::Forecast; break; - default: return MessageType::Unknown; break; + switch (dataBuffer[0]) { + case 0: + return MessageType::CurrentWeather; + break; + case 1: + return MessageType::Forecast; + break; + default: + return MessageType::Unknown; + break; } } @@ -74,7 +74,6 @@ int WeatherCallback(uint16_t /*connHandle*/, uint16_t /*attrHandle*/, struct ble } SimpleWeatherService::SimpleWeatherService(const DateTime& dateTimeController) : dateTimeController(dateTimeController) { - } void SimpleWeatherService::Init() { @@ -86,9 +85,9 @@ int SimpleWeatherService::OnCommand(struct ble_gatt_access_ctxt* ctxt) { const auto* buffer = ctxt->om; const auto* dataBuffer = buffer->om_data; - switch(GetMessageType(dataBuffer)) { + switch (GetMessageType(dataBuffer)) { case MessageType::CurrentWeather: - if(GetVersion(dataBuffer) == 0) { + if (GetVersion(dataBuffer) == 0) { currentWeather = CreateCurrentWeather(dataBuffer); NRF_LOG_INFO("Current weather :\n\tTimestamp : %d\n\tTemperature:%d\n\tMin:%d\n\tMax:%d\n\tIcon:%d\n\tLocation:%s", currentWeather->timestamp, @@ -100,11 +99,15 @@ int SimpleWeatherService::OnCommand(struct ble_gatt_access_ctxt* ctxt) { } break; case MessageType::Forecast: - if(GetVersion(dataBuffer) == 0) { + if (GetVersion(dataBuffer) == 0) { forecast = CreateForecast(dataBuffer); NRF_LOG_INFO("Forecast : Timestamp : %d", forecast->timestamp); - for(int i = 0; i < 5; i++) { - NRF_LOG_INFO("\t[%d] Min: %d - Max : %d - Icon : %d", i, forecast->days[i].minTemperature, forecast->days[i].maxTemperature, forecast->days[i].iconId); + for (int i = 0; i < 5; i++) { + NRF_LOG_INFO("\t[%d] Min: %d - Max : %d - Icon : %d", + i, + forecast->days[i].minTemperature, + forecast->days[i].maxTemperature, + forecast->days[i].iconId); } } break; @@ -116,13 +119,13 @@ int SimpleWeatherService::OnCommand(struct ble_gatt_access_ctxt* ctxt) { } std::optional SimpleWeatherService::Current() const { - if(currentWeather) { + if (currentWeather) { auto currentTime = dateTimeController.UTCDateTime().time_since_epoch(); - auto weatherTpSecond = std::chrono::seconds{currentWeather->timestamp}; + auto weatherTpSecond = std::chrono::seconds {currentWeather->timestamp}; auto weatherTp = std::chrono::duration_cast(weatherTpSecond); auto delta = currentTime - weatherTp; - if(delta < std::chrono::hours{24}) { + if (delta < std::chrono::hours {24}) { return currentWeather; } } @@ -130,13 +133,13 @@ std::optional SimpleWeatherService::Curren } std::optional SimpleWeatherService::GetForecast() const { - if(forecast) { + if (forecast) { auto currentTime = dateTimeController.UTCDateTime().time_since_epoch(); - auto weatherTpSecond = std::chrono::seconds{forecast->timestamp}; + auto weatherTpSecond = std::chrono::seconds {forecast->timestamp}; auto weatherTp = std::chrono::duration_cast(weatherTpSecond); auto delta = currentTime - weatherTp; - if(delta < std::chrono::hours{24}) { + if (delta < std::chrono::hours {24}) { return this->forecast; } } diff --git a/src/components/ble/SimpleWeatherService.h b/src/components/ble/SimpleWeatherService.h index 46d5e187f3..9a023af1e7 100644 --- a/src/components/ble/SimpleWeatherService.h +++ b/src/components/ble/SimpleWeatherService.h @@ -47,12 +47,12 @@ namespace Pinetime { int OnCommand(struct ble_gatt_access_ctxt* ctxt); enum class Icons : uint8_t { - Sun = 0, // ClearSky + Sun = 0, // ClearSky CloudsSun = 1, // FewClouds - Clouds = 2, // Scattered clouds + Clouds = 2, // Scattered clouds BrokenClouds = 3, CloudShowerHeavy = 4, // shower rain - CloudSunRain = 5, // rain + CloudSunRain = 5, // rain Thunderstorm = 6, Snow = 7, Smog = 8, // Mist @@ -60,13 +60,21 @@ namespace Pinetime { }; struct CurrentWeather { - CurrentWeather(uint64_t timestamp, uint8_t temperature, uint8_t minTemperature, uint8_t maxTemperature, - uint8_t iconId, const char* location) - : timestamp{timestamp}, temperature{temperature}, minTemperature{minTemperature}, maxTemperature{maxTemperature}, - iconId{iconId} { + CurrentWeather(uint64_t timestamp, + uint8_t temperature, + uint8_t minTemperature, + uint8_t maxTemperature, + uint8_t iconId, + const char* location) + : timestamp {timestamp}, + temperature {temperature}, + minTemperature {minTemperature}, + maxTemperature {maxTemperature}, + iconId {iconId} { std::memcpy(this->location, location, 32); this->location[32] = 0; } + uint64_t timestamp; uint8_t temperature; uint8_t minTemperature; @@ -81,18 +89,19 @@ namespace Pinetime { struct Forecast { uint64_t timestamp; uint8_t nbDays; + struct Day { uint8_t minTemperature; uint8_t maxTemperature; uint8_t iconId; }; + std::array days; }; std::optional Current() const; std::optional GetForecast() const; - private: // 00050000-78fc-48fe-8e23-433b3a1942d0 static constexpr ble_uuid128_t BaseUuid() { @@ -109,13 +118,12 @@ namespace Pinetime { ble_uuid128_t weatherDataCharUuid {CharUuid(0x00, 0x01)}; - const struct ble_gatt_chr_def characteristicDefinition[2] = { - {.uuid = &weatherDataCharUuid.u, - .access_cb = WeatherCallback, - .arg = this, - .flags = BLE_GATT_CHR_F_WRITE, - .val_handle = &eventHandle}, - {0}}; + const struct ble_gatt_chr_def characteristicDefinition[2] = {{.uuid = &weatherDataCharUuid.u, + .access_cb = WeatherCallback, + .arg = this, + .flags = BLE_GATT_CHR_F_WRITE, + .val_handle = &eventHandle}, + {0}}; const struct ble_gatt_svc_def serviceDefinition[2] = { {.type = BLE_GATT_SVC_TYPE_PRIMARY, .uuid = &weatherUuid.u, .characteristics = characteristicDefinition}, {0}}; diff --git a/src/displayapp/DisplayAppRecovery.cpp b/src/displayapp/DisplayAppRecovery.cpp index 9fe59c40a8..c4bd57669b 100644 --- a/src/displayapp/DisplayAppRecovery.cpp +++ b/src/displayapp/DisplayAppRecovery.cpp @@ -122,7 +122,7 @@ void DisplayApp::PushMessage(Display::Messages msg) { void DisplayApp::Register(Pinetime::System::SystemTask* /*systemTask*/) { } -void DisplayApp::Register(Pinetime::Controllers::WeatherService* /*weatherService*/) { +void DisplayApp::Register(Pinetime::Controllers::SimpleWeatherService* /*weatherService*/) { } void DisplayApp::Register(Pinetime::Controllers::MusicService* /*musicService*/) { diff --git a/src/displayapp/DisplayAppRecovery.h b/src/displayapp/DisplayAppRecovery.h index 41aedb1793..fd79ef287b 100644 --- a/src/displayapp/DisplayAppRecovery.h +++ b/src/displayapp/DisplayAppRecovery.h @@ -34,7 +34,7 @@ namespace Pinetime { class AlarmController; class BrightnessController; class FS; - class WeatherService; + class SimpleWeatherService; class MusicService; class NavigationService; } @@ -69,7 +69,7 @@ namespace Pinetime { void PushMessage(Pinetime::Applications::Display::Messages msg); void Register(Pinetime::System::SystemTask* systemTask); - void Register(Pinetime::Controllers::WeatherService* weatherService); + void Register(Pinetime::Controllers::SimpleWeatherService* weatherService); void Register(Pinetime::Controllers::MusicService* musicService); void Register(Pinetime::Controllers::NavigationService* NavigationService); diff --git a/src/displayapp/screens/WatchFacePineTimeStyle.cpp b/src/displayapp/screens/WatchFacePineTimeStyle.cpp index 6512249341..baa2e1845b 100644 --- a/src/displayapp/screens/WatchFacePineTimeStyle.cpp +++ b/src/displayapp/screens/WatchFacePineTimeStyle.cpp @@ -45,16 +45,36 @@ namespace { const char* GetIcon(const Pinetime::Controllers::SimpleWeatherService::Icons icon) { switch (icon) { - case Pinetime::Controllers::SimpleWeatherService::Icons::Sun: return Symbols::sun; break; - case Pinetime::Controllers::SimpleWeatherService::Icons::CloudsSun: return Symbols::cloudSun; break; - case Pinetime::Controllers::SimpleWeatherService::Icons::Clouds: return Symbols::cloud; break; - case Pinetime::Controllers::SimpleWeatherService::Icons::BrokenClouds: return Symbols::cloud; break; // TODO missing symbol - case Pinetime::Controllers::SimpleWeatherService::Icons::Thunderstorm: return Symbols::cloud; break; // TODO missing symbol - case Pinetime::Controllers::SimpleWeatherService::Icons::Snow: return Symbols::cloud; break; // TODO missing symbol - case Pinetime::Controllers::SimpleWeatherService::Icons::CloudShowerHeavy: return Symbols::cloudShowersHeavy; break; - case Pinetime::Controllers::SimpleWeatherService::Icons::CloudSunRain: return Symbols::cloudSunRain; break; - case Pinetime::Controllers::SimpleWeatherService::Icons::Smog: return Symbols::smog; break; - default: return Symbols::ban; break; + case Pinetime::Controllers::SimpleWeatherService::Icons::Sun: + return Symbols::sun; + break; + case Pinetime::Controllers::SimpleWeatherService::Icons::CloudsSun: + return Symbols::cloudSun; + break; + case Pinetime::Controllers::SimpleWeatherService::Icons::Clouds: + return Symbols::cloud; + break; + case Pinetime::Controllers::SimpleWeatherService::Icons::BrokenClouds: + return Symbols::cloud; + break; // TODO missing symbol + case Pinetime::Controllers::SimpleWeatherService::Icons::Thunderstorm: + return Symbols::cloud; + break; // TODO missing symbol + case Pinetime::Controllers::SimpleWeatherService::Icons::Snow: + return Symbols::cloud; + break; // TODO missing symbol + case Pinetime::Controllers::SimpleWeatherService::Icons::CloudShowerHeavy: + return Symbols::cloudShowersHeavy; + break; + case Pinetime::Controllers::SimpleWeatherService::Icons::CloudSunRain: + return Symbols::cloudSunRain; + break; + case Pinetime::Controllers::SimpleWeatherService::Icons::Smog: + return Symbols::smog; + break; + default: + return Symbols::ban; + break; } } }