diff options
Diffstat (limited to 'apps')
-rw-r--r-- | apps/home_menu/main.cpp (renamed from apps/home_menu.cpp) | 9 | ||||
-rw-r--r-- | apps/home_menu/main.hpp (renamed from apps/home_menu.hpp) | 8 | ||||
-rw-r--r-- | apps/main_clock.cpp | 96 | ||||
-rw-r--r-- | apps/main_clock.hpp | 17 | ||||
-rw-r--r-- | apps/main_clock/main.cpp | 93 | ||||
-rw-r--r-- | apps/main_clock/main.hpp | 36 | ||||
-rw-r--r-- | apps/settings/main.cpp | 1 |
7 files changed, 139 insertions, 121 deletions
diff --git a/apps/home_menu.cpp b/apps/home_menu/main.cpp index 4761c46..02965c3 100644 --- a/apps/home_menu.cpp +++ b/apps/home_menu/main.cpp @@ -1,11 +1,10 @@ #include <stdio.h> #include "pico/stdlib.h" -#include "home_menu.hpp" -#include "../api.hpp" -#include "../buttons.hpp" +#include "../../globals.hpp" +#include "../../app_manager.hpp" +#include "main.hpp" -extern void app_switch(int old_appid, int new_appid); extern bool rtc_get_datetime(datetime_t *t); void app_home_menu::title_str(char *buf, uint buf_size, const datetime_t *t) { @@ -40,7 +39,7 @@ int app_home_menu::render(Api *app_api) { int app_home_menu::btnpressed(Api *app_api, uint gpio, unsigned long delta) { switch (gpio) { case BUTTON_SELECT: - app_switch(0, selected_app); // FIXME: Should call app_switch_request instead + app_switch_request( selected_app); return 0; case BUTTON_DOWN: selected_app--; diff --git a/apps/home_menu.hpp b/apps/home_menu/main.hpp index dce83e4..421789b 100644 --- a/apps/home_menu.hpp +++ b/apps/home_menu/main.hpp @@ -1,10 +1,9 @@ #pragma once #include "pico/util/datetime.h" -#include "../oled/ss_oled.h" -#include "../api.hpp" -#include "../base_app.hpp" +// Includes also buttons, API and ss_oled +#include "../../base_app.hpp" #define NUMBER_OF_APPS 3 #define SIZE_APP_NAME 12 @@ -14,10 +13,13 @@ class app_home_menu : public BaseApp { const char *APPS_NAME[NUMBER_OF_APPS] = {"Home", "Clock", "Settings"}; int selected_app = 0; char display_app_name[SIZE_APP_NAME]; + void title_str(char *buf, uint buf_size, const datetime_t *t); void show_title(Api *app_api); public: uint app_id = 0; + bool app_destroy_on_exit = false; + app_home_menu(Api *app_api); int render(Api *app_api); int btnpressed(Api *app_api, uint gpio, unsigned long delta); diff --git a/apps/main_clock.cpp b/apps/main_clock.cpp deleted file mode 100644 index 24a4dfb..0000000 --- a/apps/main_clock.cpp +++ /dev/null @@ -1,96 +0,0 @@ -#include <stdio.h> -#include "pico/stdlib.h" - -#include "main_clock.hpp" -#include "../api.hpp" -#include "../buttons.hpp" - -namespace app_main_clock { - bool *ask_user_choice; - int *user_choice; - const char *choices[] = {"One", "Two", "Three!", "This is looong!", "make sure to choose me!:p"}; - // Time as string - // Adapted from pico-sdk/scr/common/pico_util/datetime.c - void time_as_str(char *buf, uint buf_size, const datetime_t *t) { - snprintf(buf, - buf_size, - "%d:%02d:%02d ", - t->hour, - t->min, - t->sec); - }; - void date_as_str(char *buf, uint buf_size, const datetime_t *t) { - static const char *DATETIME_DOWS[7] = { - "Sun", - "Mon", - "Tue", - "Wed", - "Thu", - "Fri", - "Sat", - }; - snprintf(buf, - buf_size, - "%02d-%02d-%02d %s", - t->year, - t->month, - t->day, - DATETIME_DOWS[t->dotw]); - }; - - void show_datetime(Api *app_api) { - char datetime_buf[256]; - char *datetime_str = &datetime_buf[0]; - datetime_t t; - app_api->datetime_get(&t); - - // time - time_as_str(datetime_str, sizeof(datetime_buf), &t); - app_api->display_write_string(0,10,3, datetime_str, FONT_12x16, 0, 1); - - // date - date_as_str(datetime_str, sizeof(datetime_buf), &t); - app_api->gui_footer_text((std::string)datetime_str); - } - - // Rendering of the app - int render(Api *app_api) { - app_api->gui_header_text("Test clock", 17); - show_datetime(app_api); - if (*ask_user_choice) { - *user_choice = app_api->gui_popup_strchoice("Ohh!", "Make a good choice:", choices, 5, 0, -1, *user_choice); - *ask_user_choice = false; - } - app_api->gui_footer_text(choices[*user_choice],0,1); - return 0; - } - - // Interpretation of button inputs - int btnpressed(Api *app_api, uint gpio, unsigned long delta) { - if (gpio == BUTTON_MODE) - *ask_user_choice = true; - return 0; - } - - // Initlisation of the app. - int init(Api *app_api) { - app_api->performance_set(Api::perf_modes::LOW_POWER); - ask_user_choice = new bool; *ask_user_choice = false; - user_choice = new int; *user_choice = 0; - if (!(user_choice or ask_user_choice)) - return Api::app_init_return_status::MALLOC_FAILED; - return Api::app_init_return_status::OK; - } - - // Processor intensive operations and functions related to drawing to the screen should only be done when the app is in_foreground(=1). This function is only called when the app is init. - int bgrefresh(Api *app_api, bool in_foreground) { - return 1; - } - - // Destruction of app, deinitlisation should be done here. This is only called if the app's APPS_DESTROY_ON_EXIT is set to 1. When it is not a "service" app. - int destroy(Api *app_api) { - delete ask_user_choice; ask_user_choice = 0; - delete user_choice; user_choice = 0; - return 0; - } -} diff --git a/apps/main_clock.hpp b/apps/main_clock.hpp deleted file mode 100644 index 72e02a4..0000000 --- a/apps/main_clock.hpp +++ /dev/null @@ -1,17 +0,0 @@ -#ifndef __MAIN_CLOCK_H__ -#define __MAIN_CLOCK_H__ - -#include "pico/util/datetime.h" -#include "../oled/ss_oled.h" - -#include "../api.hpp" - -namespace app_main_clock { - int init(Api *app_api); - int render(Api *app_api); - int btnpressed(Api *app_api, uint gpio, unsigned long delta); - int bgrefresh(Api *app_api, bool in_foreground); - int destroy(Api *app_api); -} - -#endif
\ No newline at end of file diff --git a/apps/main_clock/main.cpp b/apps/main_clock/main.cpp new file mode 100644 index 0000000..78be6fd --- /dev/null +++ b/apps/main_clock/main.cpp @@ -0,0 +1,93 @@ +#include <stdio.h> +#include "pico/stdlib.h" + +#include "main.hpp" + +// TODO in this app +// - No need for ask_user_choice and user_choice to be a ptr as the app is now encapsulated in a class. + +// Time as string +// Adapted from pico-sdk/scr/common/pico_util/datetime.c +void app_main_clock::time_as_str(char *buf, uint buf_size, const datetime_t *t) { + snprintf(buf, + buf_size, + "%d:%02d:%02d ", + t->hour, + t->min, + t->sec); +}; + +void app_main_clock::date_as_str(char *buf, uint buf_size, const datetime_t *t) { + static const char *DATETIME_DOWS[7] = { + "Sun", + "Mon", + "Tue", + "Wed", + "Thu", + "Fri", + "Sat", + }; + snprintf(buf, + buf_size, + "%02d-%02d-%02d %s", + t->year, + t->month, + t->day, + DATETIME_DOWS[t->dotw]); +}; + +void app_main_clock::show_datetime(Api *app_api) { + char datetime_buf[256]; + char *datetime_str = &datetime_buf[0]; + datetime_t t; + app_api->datetime_get(&t); + + // time + time_as_str(datetime_str, sizeof(datetime_buf), &t); + app_api->display_write_string(0,10,3, datetime_str, FONT_12x16, 0, 1); + + // date + date_as_str(datetime_str, sizeof(datetime_buf), &t); + app_api->gui_footer_text((std::string)datetime_str); +} + +// Rendering of the app +int app_main_clock::render(Api *app_api) { + app_api->gui_header_text("Test clock", 17); + show_datetime(app_api); + if (*ask_user_choice) { + *user_choice = app_api->gui_popup_strchoice("Ohh!", "Make a good choice:", choices, 5, 0, -1, *user_choice); + *ask_user_choice = false; + } + app_api->gui_footer_text(choices[*user_choice],0,1); + return 0; +} + +// Interpretation of button inputs +int app_main_clock::btnpressed(Api *app_api, uint gpio, unsigned long delta) { + if (gpio == BUTTON_MODE) + *ask_user_choice = true; + return 0; +} + +// Initlisation of the app. +app_main_clock::app_main_clock(Api *app_api) { + app_api->performance_set(Api::perf_modes::LOW_POWER); + + ask_user_choice = new bool; *ask_user_choice = false; + user_choice = new int; *user_choice = 0; + // if (!(user_choice or ask_user_choice)) + // return Api::app_init_return_status::MALLOC_FAILED; + // return Api::app_init_return_status::OK; +} + +// Processor intensive operations and functions related to drawing to the screen should only be done when the app is in_foreground(=1). This function is only called when the app is init. +int app_main_clock::bgrefresh(Api *app_api, bool in_foreground) { + return 1; +} + +// Destruction of app, deinitlisation should be done here. This is only called if the app's APPS_DESTROY_ON_EXIT is set to 1. When it is not a "service" app. +app_main_clock::~app_main_clock() { + delete ask_user_choice; ask_user_choice = 0; + delete user_choice; user_choice = 0; +} diff --git a/apps/main_clock/main.hpp b/apps/main_clock/main.hpp new file mode 100644 index 0000000..37c9075 --- /dev/null +++ b/apps/main_clock/main.hpp @@ -0,0 +1,36 @@ +#pragma once + +#include "pico/util/datetime.h" + +// Includes also buttons, API and ss_oled +#include "../../base_app.hpp" + +class app_main_clock : public BaseApp { + private: + bool *ask_user_choice; + int *user_choice; + const char *choices[26] = {"One", "Two", "Three!", "This is looong!", "make sure to choose me!:p"}; + + void time_as_str(char *buf, uint buf_size, const datetime_t *t); + void date_as_str(char *buf, uint buf_size, const datetime_t *t); + void show_datetime(Api *app_api); + + public: + uint app_id = 1; + bool app_destroy_on_exit = true; + + app_main_clock(Api *app_api); + int render(Api *app_api); + int btnpressed(Api *app_api, uint gpio, unsigned long delta); + int bgrefresh(Api *app_api, bool in_foreground); + ~app_main_clock(); +}; + + +/* namespace app_main_clock { + int init(Api *app_api); + int render(Api *app_api); + int btnpressed(Api *app_api, uint gpio, unsigned long delta); + int bgrefresh(Api *app_api, bool in_foreground); + int destroy(Api *app_api); +} */ diff --git a/apps/settings/main.cpp b/apps/settings/main.cpp index 5472adf..26c8e25 100644 --- a/apps/settings/main.cpp +++ b/apps/settings/main.cpp @@ -3,6 +3,7 @@ #include "main.hpp" #include "../../api.hpp" +#include "../../globals.hpp" extern void app_switch(int old_appid, int new_appid); extern bool rtc_get_datetime(datetime_t *t); |