aboutsummaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
Diffstat (limited to 'apps')
-rw-r--r--apps/home_menu.cpp50
-rw-r--r--apps/home_menu.hpp10
-rw-r--r--apps/main_clock.cpp29
-rw-r--r--apps/main_clock.hpp10
4 files changed, 45 insertions, 54 deletions
diff --git a/apps/home_menu.cpp b/apps/home_menu.cpp
index 30caed0..7f53447 100644
--- a/apps/home_menu.cpp
+++ b/apps/home_menu.cpp
@@ -16,6 +16,8 @@ extern bool rtc_get_datetime(datetime_t *t);
namespace app_home_menu {
const char* APPS_NAME[NUMBER_OF_APPS][12] = {"Home", "Clock"};
+ char *pressed_button;
+ int *selected_app;
void title_str(char *buf, uint buf_size, const datetime_t *t) {
snprintf(buf,
@@ -38,56 +40,60 @@ namespace app_home_menu {
}
// Rendering of app
- int render(SSOLED *oled, char *data, uint data_size) {
+ int render(SSOLED *oled) {
show_title(oled);
- oledWriteString(oled, 0,0,2, &data[0], FONT_6x8, 0, 1);
- oledWriteString(oled, 0,5,3, const_cast<char*>(APPS_NAME[data[1]][0]), FONT_12x16, 0, 1); // FIXME: The name does not update, it seems that the second string is empty… but data[1]'s content is correct, as BUTTON_SELECT switches to the correct app.
+ oledWriteString(oled, 0,0,2, pressed_button, FONT_6x8, 0, 1);
+ oledWriteString(oled, 0,5,3, const_cast<char*>(APPS_NAME[0][*selected_app]), FONT_12x16, 0, 1);
return 0;
}
- // Interpret button inputs
- int btnpressed(SSOLED *oled, char *data, uint data_size, uint gpio) {
+ // Example of how button inputs could be interpreted.
+ // Drawing on screen should be done in the render function.
+ int btnpressed(SSOLED *oled, uint gpio) {
switch (gpio) {
case BUTTON_HOME:
- data[0] = 'H'; break;
+ *pressed_button = 'H'; break;
case BUTTON_SELECT:
- data[0] = 'S';
- app_switch(0, data[1]);
+ *pressed_button = 'S';
+ app_switch(0, *selected_app);
break;
case BUTTON_MODE:
- data[0] = 'M'; break;
+ *pressed_button = 'M'; break;
case BUTTON_DOWN:
- data[0] = 'D';
- data[1]--;
+ *pressed_button = 'D';
+ *selected_app--;
break;
case BUTTON_UP:
- data[0] = 'U';
- data[1]++;
+ *pressed_button = 'U';
+ *selected_app++;
break;
default:
- data[0] = '?';
+ *pressed_button = '?';
}
- if (data[1] > NUMBER_OF_APPS-1) {
- data[1] = NUMBER_OF_APPS-1; data[0] = '>';
- } else if (data[1] < NUMBER_OF_APPS-1) {
- data[1] = 0; data[0] = '<';
+ if (*selected_app > NUMBER_OF_APPS-1) {
+ *selected_app = NUMBER_OF_APPS-1; *pressed_button = '>';
+ } else if (*selected_app < NUMBER_OF_APPS-1) {
+ *selected_app = 0; *pressed_button = '<';
}
return 0;
}
// Initlisation of the app.
- int init(SSOLED *oled, char *data, uint data_size) {
- data[1] = 0;
+ int init(SSOLED *oled) {
+ pressed_button = new char; *pressed_button = '*';
+ selected_app = new int;
return 0; // return 1 when function not implemented
}
// 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(SSOLED *oled, char *data, uint data_size, char in_foreground) {
+ int bgrefresh(SSOLED *oled, char 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(SSOLED *oled, char *data, uint data_size) {
+ int destroy(SSOLED *oled) {
+ delete pressed_button; pressed_button = nullptr;
+ delete selected_app; selected_app = nullptr;
return 1;
}
}
diff --git a/apps/home_menu.hpp b/apps/home_menu.hpp
index bd648d3..ebcc451 100644
--- a/apps/home_menu.hpp
+++ b/apps/home_menu.hpp
@@ -5,11 +5,11 @@
#include "../oled/ss_oled.h"
namespace app_home_menu {
- int init(SSOLED *oled, char *data, uint data_size);
- int render(SSOLED *oled, char *data, uint data_size);
- int btnpressed(SSOLED *oled, char *data, uint data_size, uint gpio);
- int bgrefresh(SSOLED *oled, char *data, uint data_size, char in_foreground);
- int destroy(SSOLED *oled, char *data, uint data_size);
+ int init(SSOLED *oled);
+ int render(SSOLED *oled);
+ int btnpressed(SSOLED *oled, uint gpio);
+ int bgrefresh(SSOLED *oled, char in_foreground);
+ int destroy(SSOLED *oled);
}
#endif
diff --git a/apps/main_clock.cpp b/apps/main_clock.cpp
index 326c0f4..f9be3e5 100644
--- a/apps/main_clock.cpp
+++ b/apps/main_clock.cpp
@@ -55,45 +55,30 @@ namespace app_main_clock {
}
// Rendering of the app
- int render(SSOLED *oled, char *data, uint data_size) {
+ int render(SSOLED *oled) {
oledWriteString(oled, 0,15,0, (char *)"Test clock", FONT_8x8, 0, 1);
show_datetime(oled);
- oledWriteString(oled, 0,0,0, &data[0], FONT_6x8, 0, 1);
+ //oledWriteString(oled, 0,0,0, &data[0], FONT_6x8, 0, 1);
return 0;
}
- // Example of how button inputs could be interpreted.
- // Drawing on screen should be done in the render function.
- int btnpressed(SSOLED *oled, char *data, uint data_size, uint gpio) {
- switch (gpio) {
- case BUTTON_HOME: // Apps will generally not receive the Home button press
- data[0] = 'H'; break;
- case BUTTON_SELECT:
- data[0] = 'S'; break;
- case BUTTON_MODE:
- data[0] = 'M'; break;
- case BUTTON_DOWN:
- data[0] = 'D'; break;
- case BUTTON_UP:
- data[0] = 'U'; break;
- default:
- data[0] = '?';
- }
+ // Interpretation of button inputs
+ int btnpressed(SSOLED *oled, uint gpio) {
return 0;
}
// Initlisation of the app.
- int init(SSOLED *oled, char *data, uint data_size) {
+ int init(SSOLED *oled) {
return 1; // return 1 when function not implemented
}
// 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(SSOLED *oled, char *data, uint data_size, char in_foreground) {
+ int bgrefresh(SSOLED *oled, char 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(SSOLED *oled, char *data, uint data_size) {
+ int destroy(SSOLED *oled) {
return 1;
}
} \ No newline at end of file
diff --git a/apps/main_clock.hpp b/apps/main_clock.hpp
index c20af0f..887dfa1 100644
--- a/apps/main_clock.hpp
+++ b/apps/main_clock.hpp
@@ -5,11 +5,11 @@
#include "../oled/ss_oled.h"
namespace app_main_clock {
- int init(SSOLED *oled, char *data, uint data_size);
- int render(SSOLED *oled, char *data, uint data_size);
- int btnpressed(SSOLED *oled, char *data, uint data_size, uint gpio);
- int bgrefresh(SSOLED *oled, char *data, uint data_size, char in_foreground);
- int destroy(SSOLED *oled, char *data, uint data_size);
+ int init(SSOLED *oled);
+ int render(SSOLED *oled);
+ int btnpressed(SSOLED *oled, uint gpio);
+ int bgrefresh(SSOLED *oled, char in_foreground);
+ int destroy(SSOLED *oled);
}
#endif \ No newline at end of file