summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatheus Afonso Martins Moreira <matheus.a.m.moreira@gmail.com>2024-02-25 12:40:00 -0300
committerMatheus Afonso Martins Moreira <matheus.a.m.moreira@gmail.com>2024-02-25 15:24:14 -0300
commit76add5a2da6c28e1701d0a69244fc3b3a71c1e67 (patch)
treeb8902ffed755c427e47962f23dee9badc36e891c
parent1d79930ab79835222e76567f520a53379ad0546b (diff)
downloadSensor-Watch-76add5a2da6c28e1701d0a69244fc3b3a71c1e67.tar.gz
Sensor-Watch-76add5a2da6c28e1701d0a69244fc3b3a71c1e67.tar.bz2
Sensor-Watch-76add5a2da6c28e1701d0a69244fc3b3a71c1e67.zip
faces/clock: refactor tick tock animation code
Simplifies the code by defining dedicated functions for this.
-rw-r--r--movement/watch_faces/clock/clock_face.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/movement/watch_faces/clock/clock_face.c b/movement/watch_faces/clock/clock_face.c
index 1977ca75..82052133 100644
--- a/movement/watch_faces/clock/clock_face.c
+++ b/movement/watch_faces/clock/clock_face.c
@@ -100,7 +100,7 @@ static void clock_indicate_low_available_power(clock_state_t *clock) {
}
static void clock_display_low_energy(watch_date_time date_time) {
- char buf[11];
+ char buf[10 + 1];
snprintf(
buf,
@@ -115,6 +115,18 @@ static void clock_display_low_energy(watch_date_time date_time) {
watch_display_string(buf, 0);
}
+static void clock_start_tick_tock_animation(void) {
+ if (!watch_tick_animation_is_running()) {
+ watch_start_tick_animation(500);
+ }
+}
+
+static void clock_stop_tick_tock_animation(void) {
+ if (watch_tick_animation_is_running()) {
+ watch_stop_tick_animation();
+ }
+}
+
void clock_face_setup(movement_settings_t *settings, uint8_t watch_face_index, void ** context_ptr) {
(void) settings;
(void) watch_face_index;
@@ -130,7 +142,7 @@ void clock_face_setup(movement_settings_t *settings, uint8_t watch_face_index, v
void clock_face_activate(movement_settings_t *settings, void *context) {
clock_state_t *clock = (clock_state_t *) context;
- if (watch_tick_animation_is_running()) watch_stop_tick_animation();
+ clock_stop_tick_tock_animation();
clock_indicate_time_signal(clock);
clock_indicate_alarm(settings);
@@ -151,7 +163,7 @@ bool clock_face_loop(movement_event_t event, movement_settings_t *settings, void
uint32_t previous_date_time;
switch (event.event_type) {
case EVENT_LOW_ENERGY_UPDATE:
- if (!watch_tick_animation_is_running()) watch_start_tick_animation(500);
+ clock_start_tick_tock_animation();
clock_display_low_energy(watch_rtc_get_date_time());
break;
case EVENT_TICK: