SimpleWeatherService: Generate forecast data
This commit is contained in:
parent
bb18300c9e
commit
30abc55b6c
3 changed files with 42 additions and 7 deletions
20
main.cpp
20
main.cpp
|
@ -802,19 +802,27 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
void generate_weather_data(bool clear) {
|
void generate_weather_data(bool clear) {
|
||||||
static int iconId = -1;
|
|
||||||
if (clear) {
|
if (clear) {
|
||||||
systemTask.nimble().weather().SetCurrentWeather(0, 0, 0);
|
systemTask.nimble().weather().SetCurrentWeather(0, 0, 0);
|
||||||
|
std::array<Pinetime::Controllers::SimpleWeatherService::Forecast::Day, Pinetime::Controllers::SimpleWeatherService::MaxNbForecastDays> days;
|
||||||
|
systemTask.nimble().weather().SetForecast(0, days);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto timestamp = std::chrono::system_clock::to_time_t(std::chrono::system_clock::now());
|
auto timestamp = std::chrono::system_clock::to_time_t(std::chrono::system_clock::now());
|
||||||
srand((int)timestamp);
|
srand((int)timestamp);
|
||||||
int temperature = (rand() % 81 - 40) * 100;
|
|
||||||
iconId++;
|
// Generate current weather data
|
||||||
if (iconId > 8) {
|
int16_t temperature = (rand() % 81 - 40) * 100;
|
||||||
iconId = 0;
|
systemTask.nimble().weather().SetCurrentWeather((uint64_t)timestamp, temperature, rand() % 9);
|
||||||
|
|
||||||
|
// Generate forecast data
|
||||||
|
std::array<Pinetime::Controllers::SimpleWeatherService::Forecast::Day, Pinetime::Controllers::SimpleWeatherService::MaxNbForecastDays> days;
|
||||||
|
for (int i = 0; i < Pinetime::Controllers::SimpleWeatherService::MaxNbForecastDays; i++) {
|
||||||
|
days[i] = Pinetime::Controllers::SimpleWeatherService::Forecast::Day {
|
||||||
|
(int16_t)(temperature - rand() % 10 * 100), (int16_t)(temperature + rand() % 10 * 100), Pinetime::Controllers::SimpleWeatherService::Icons(rand() % 9)
|
||||||
|
};
|
||||||
}
|
}
|
||||||
systemTask.nimble().weather().SetCurrentWeather((uint64_t)timestamp, temperature, iconId);
|
systemTask.nimble().weather().SetForecast((uint64_t)timestamp, days);
|
||||||
}
|
}
|
||||||
|
|
||||||
void handle_touch_and_button() {
|
void handle_touch_and_button() {
|
||||||
|
|
|
@ -77,6 +77,13 @@ void SimpleWeatherService::SetCurrentWeather(uint64_t timestamp, int16_t tempera
|
||||||
printf("currentWeather: timestamp=%d, temperature=%d, icon=%d\n", currentWeather->timestamp, currentWeather->temperature, currentWeather->iconId);
|
printf("currentWeather: timestamp=%d, temperature=%d, icon=%d\n", currentWeather->timestamp, currentWeather->temperature, currentWeather->iconId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SimpleWeatherService::SetForecast(uint64_t timestamp, std::array<SimpleWeatherService::Forecast::Day, SimpleWeatherService::MaxNbForecastDays> days) {
|
||||||
|
forecast = SimpleWeatherService::Forecast {timestamp, SimpleWeatherService::MaxNbForecastDays, days};
|
||||||
|
for (int i = 0; i < SimpleWeatherService::MaxNbForecastDays; i++) {
|
||||||
|
printf("forecast: day=%d. min=%d, max=%d icon=%d\n", i, days[i].minTemperature, days[i].maxTemperature, days[i].iconId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int SimpleWeatherService::OnCommand(struct ble_gatt_access_ctxt* ctxt) {
|
int SimpleWeatherService::OnCommand(struct ble_gatt_access_ctxt* ctxt) {
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -115,3 +122,17 @@ bool SimpleWeatherService::CurrentWeather::operator==(const SimpleWeatherService
|
||||||
this->maxTemperature == other.maxTemperature && this->minTemperature == other.maxTemperature &&
|
this->maxTemperature == other.maxTemperature && this->minTemperature == other.maxTemperature &&
|
||||||
std::strcmp(this->location.data(), other.location.data()) == 0;
|
std::strcmp(this->location.data(), other.location.data()) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool SimpleWeatherService::Forecast::Day::operator==(const SimpleWeatherService::Forecast::Day& other) const {
|
||||||
|
return this->iconId == other.iconId &&
|
||||||
|
this->maxTemperature == other.maxTemperature && this->minTemperature == other.maxTemperature;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SimpleWeatherService::Forecast::operator==(const SimpleWeatherService::Forecast& other) const {
|
||||||
|
for (int i = 0; i < this->nbDays; i++) {
|
||||||
|
if (this->days[i] != other.days[i]) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this->timestamp == other.timestamp && this->nbDays == other.nbDays;
|
||||||
|
}
|
||||||
|
|
|
@ -27,7 +27,6 @@ public:
|
||||||
explicit SimpleWeatherService(const DateTime& dateTimeController);
|
explicit SimpleWeatherService(const DateTime& dateTimeController);
|
||||||
|
|
||||||
void Init();
|
void Init();
|
||||||
void SetCurrentWeather(uint64_t timestamp, int16_t temperature, int iconId);
|
|
||||||
|
|
||||||
int OnCommand(struct ble_gatt_access_ctxt* ctxt);
|
int OnCommand(struct ble_gatt_access_ctxt* ctxt);
|
||||||
|
|
||||||
|
@ -81,11 +80,18 @@ public:
|
||||||
int16_t minTemperature;
|
int16_t minTemperature;
|
||||||
int16_t maxTemperature;
|
int16_t maxTemperature;
|
||||||
Icons iconId;
|
Icons iconId;
|
||||||
|
|
||||||
|
bool operator==(const Day& other) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
std::array<Day, MaxNbForecastDays> days;
|
std::array<Day, MaxNbForecastDays> days;
|
||||||
|
|
||||||
|
bool operator==(const Forecast& other) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void SetCurrentWeather(uint64_t timestamp, int16_t temperature, int iconId);
|
||||||
|
void SetForecast(uint64_t timestamp, std::array<Forecast::Day, MaxNbForecastDays> days);
|
||||||
|
|
||||||
std::optional<CurrentWeather> Current() const;
|
std::optional<CurrentWeather> Current() const;
|
||||||
std::optional<Forecast> GetForecast() const;
|
std::optional<Forecast> GetForecast() const;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue