let temperature screen skip itself, restore it to the default firmware

This commit is contained in:
Joey Castillo 2025-05-17 12:16:27 -04:00
parent 40a0308059
commit 63dbaad730
2 changed files with 11 additions and 2 deletions

View File

@ -35,6 +35,7 @@ const watch_face_t watch_faces[] = {
countdown_face,
stopwatch_face,
voltage_face,
temperature_display_face,
settings_face,
set_time_face
};
@ -47,7 +48,7 @@ const watch_face_t watch_faces[] = {
* Some folks also like to use this to hide the preferences and time set faces from the normal rotation.
* If you don't want any faces to be excluded, set this to 0 and a long Mode press will have no effect.
*/
#define MOVEMENT_SECONDARY_FACE_INDEX (MOVEMENT_NUM_FACES - 3)
#define MOVEMENT_SECONDARY_FACE_INDEX (MOVEMENT_NUM_FACES - 4)
/* Custom hourly chime tune. Check movement_custom_signal_tunes.h for options. */
#define SIGNAL_TUNE_DEFAULT

View File

@ -28,6 +28,8 @@
#include "thermistor_driver.h"
#include "watch.h"
static bool skip = false;
static void _temperature_display_face_update_display(bool in_fahrenheit) {
float temperature_c = movement_get_temperature();
if (in_fahrenheit) {
@ -40,11 +42,12 @@ static void _temperature_display_face_update_display(bool in_fahrenheit) {
void temperature_display_face_setup(uint8_t watch_face_index, void ** context_ptr) {
(void) watch_face_index;
(void) context_ptr;
// if temperature is invalid, we don't have a temperature sensor which means we shouldn't be here.
if (movement_get_temperature() == 0xFFFFFFFF) skip = true;
}
void temperature_display_face_activate(void *context) {
(void) context;
watch_display_text_with_fallback(WATCH_POSITION_TOP, "TEMP", "TE");
}
bool temperature_display_face_loop(movement_event_t event, void *context) {
@ -56,6 +59,11 @@ bool temperature_display_face_loop(movement_event_t event, void *context) {
_temperature_display_face_update_display(movement_use_imperial_units());
break;
case EVENT_ACTIVATE:
if (skip) {
movement_move_to_next_face();
return false;
}
watch_display_text_with_fallback(WATCH_POSITION_TOP, "TEMP", "TE");
// force a measurement to be taken immediately.
date_time.unit.second = 0;
// fall through