summaryrefslogtreecommitdiffstats
path: root/movement/watch_faces/demos/character_set_face.c
diff options
context:
space:
mode:
authorJoey Castillo <jose.castillo@gmail.com>2021-10-21 17:28:59 -0400
committerJoey Castillo <jose.castillo@gmail.com>2021-10-21 17:28:59 -0400
commitf1a706792e995f45b6b6f2ef70b2318253002249 (patch)
treef39b0640cbd40fe85105112decd19929af59c53e /movement/watch_faces/demos/character_set_face.c
parent4df23ea9f9292ab9371302f69e5192b91cbce620 (diff)
downloadSensor-Watch-f1a706792e995f45b6b6f2ef70b2318253002249.tar.gz
Sensor-Watch-f1a706792e995f45b6b6f2ef70b2318253002249.tar.bz2
Sensor-Watch-f1a706792e995f45b6b6f2ef70b2318253002249.zip
movement: add character set demo
Diffstat (limited to 'movement/watch_faces/demos/character_set_face.c')
-rw-r--r--movement/watch_faces/demos/character_set_face.c51
1 files changed, 51 insertions, 0 deletions
diff --git a/movement/watch_faces/demos/character_set_face.c b/movement/watch_faces/demos/character_set_face.c
new file mode 100644
index 00000000..7daea5a9
--- /dev/null
+++ b/movement/watch_faces/demos/character_set_face.c
@@ -0,0 +1,51 @@
+#include <stdlib.h>
+#include <string.h>
+#include "character_set_face.h"
+#include "watch.h"
+
+void character_set_face_setup(movement_settings_t *settings, void ** context_ptr) {
+ (void) settings;
+ if (*context_ptr == NULL) *context_ptr = malloc(sizeof(char));
+}
+
+void character_set_face_activate(movement_settings_t *settings, void *context) {
+ (void) settings;
+ char *c = (char *)context;
+ *c = '@';
+}
+
+bool character_set_face_loop(movement_event_t event, movement_settings_t *settings, void *context) {
+ (void) settings;
+ char *c = (char *)context;
+ char buf[11];
+ switch (event.event_type) {
+ case EVENT_MODE_BUTTON_UP:
+ movement_move_to_next_face();
+ break;
+ case EVENT_LIGHT_BUTTON_DOWN:
+ movement_illuminate_led();
+ break;
+ case EVENT_ALARM_BUTTON_UP:
+ *c = (*c) + 1;
+ if (*c & 0x80) *c = ' ';
+ // fall through
+ case EVENT_ACTIVATE:
+ sprintf(buf, "%c%c%c%c%c%c%c%c%c%c", *c, *c, *c, *c, *c, *c, *c, *c, *c, *c);
+ watch_display_string(buf, 0);
+ break;
+ case EVENT_TICK:
+ break;
+ case EVENT_TIMEOUT:
+ movement_move_to_face(0);
+ break;
+ default:
+ break;
+ }
+
+ return true;
+}
+
+void character_set_face_resign(movement_settings_t *settings, void *context) {
+ (void) settings;
+ (void) context;
+}