117 lines
4.9 KiB
C
117 lines
4.9 KiB
C
/*
|
||
* MIT License
|
||
*
|
||
* Copyright (c) 2022-2024 Joey Castillo
|
||
*
|
||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||
* of this software and associated documentation files (the "Software"), to deal
|
||
* in the Software without restriction, including without limitation the rights
|
||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||
* copies of the Software, and to permit persons to whom the Software is
|
||
* furnished to do so, subject to the following conditions:
|
||
*
|
||
* The above copyright notice and this permission notice shall be included in all
|
||
* copies or substantial portions of the Software.
|
||
*
|
||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||
* SOFTWARE.
|
||
*/
|
||
|
||
#pragma once
|
||
|
||
/*
|
||
* Legacy PREFERENCES face
|
||
*
|
||
* This face is deprecated and will be removed in a future release.
|
||
* Please use the Settings watch face instead.
|
||
*
|
||
* The Preferences watch face allows you to configure various options on your
|
||
* Sensor Watch. Like all other screens, you advance the field you’re setting
|
||
* with the Light button, and advance its value with the Alarm button. The
|
||
* Preferences watch face labels each setting with a two-letter code on the
|
||
* top row; the following list describes each setting and their options:
|
||
*
|
||
* CL - Clock mode.
|
||
* This setting allows you to select a 12-or 24-hour clock display. All
|
||
* watch faces that support displaying the time will respect this setting;
|
||
* for example, both Simple Clock, World Clock and Sunrise/Sunset will
|
||
* display the time in 24 hour format if the 24 hour clock is selected here.
|
||
*
|
||
* MO - Mode button.
|
||
* This setting allows you to choose whether the Mode button should emit
|
||
* a beep when pressed, and if so, how loud it should be. Options are
|
||
* "-" (no beep), "L" (low volume) and "H" (high volume).
|
||
*
|
||
* MO - Mode button.
|
||
* This setting allows you to choose whether the Mode button should emit
|
||
* a beep when pressed, and if so, how loud it should be. Options are
|
||
* "-" (no beep), "L" (low volume) and "H" (high volume).
|
||
*
|
||
* TO - Timeout.
|
||
* Sets the time until screens that time out (like Settings and Time Set)
|
||
* snap back to the first screen. 60 seconds is a good default for the
|
||
* stock firmware, but if you choose a custom firmware with faces that
|
||
* you’d like to keep on screen for longer, you can set that here.
|
||
*
|
||
* LE - Low Energy mode.
|
||
* Sets the time until the watch enters its low energy sleep mode.
|
||
* Options range from 1 hour to 7 days, or Never. The more often Sensor
|
||
* Watch goes to sleep, the longer its battery will last — but you will
|
||
* lose the seconds indicator while it is asleep. This setting allows
|
||
* you to make a tradeoff between the device’s responsiveness and its
|
||
* longevity.
|
||
*
|
||
* LT - Light.
|
||
* This setting has three screens.
|
||
* The first lets you choose how long the LED should stay lit when the
|
||
* LIGHT button is pressed. Options are 1 second, 3 seconds and 5
|
||
* seconds, or “No LED” to disable the LED entirely.
|
||
* The second screen, titled “blu” or “grn”, sets the intensity of the
|
||
* blue or green LED depending on the target Sensor Board hardware.
|
||
* Values range from 0 (off) to 15 (full intensity).
|
||
* The third screen, “red”, sets the intensity of the red LED, again
|
||
* from 0 to 15.
|
||
* On the last two screens, the LED remains on so that you can see the
|
||
* effect of mixing the two LED colors. On the Special Edition boards,
|
||
* you’ll have red, blue and a variety of shades of pink and purple to
|
||
* experiment with!
|
||
*/
|
||
|
||
#include "movement.h"
|
||
|
||
typedef enum {
|
||
PREFERENCES_PAGE_CLOCK_MODE = 0,
|
||
PREFERENCES_PAGE_BUTTON_SOUND,
|
||
PREFERENCES_PAGE_TIMEOUT,
|
||
PREFERENCES_PAGE_LOW_ENERGY,
|
||
PREFERENCES_PAGE_LED_DURATION,
|
||
PREFERENCES_PAGE_LED_RED,
|
||
PREFERENCES_PAGE_LED_GREEN,
|
||
PREFERENCES_PAGE_LED_BLUE,
|
||
PREFERENCES_PAGE_NUM_PREFERENCES,
|
||
} preferences_page_t;
|
||
|
||
|
||
typedef struct {
|
||
bool setting_enabled[PREFERENCES_PAGE_NUM_PREFERENCES];
|
||
preferences_page_t current_page;
|
||
} preferences_state_t;
|
||
|
||
void preferences_face_setup(uint8_t watch_face_index, void ** context_ptr);
|
||
void preferences_face_activate(void *context);
|
||
bool preferences_face_loop(movement_event_t event, void *context);
|
||
void preferences_face_resign(void *context);
|
||
|
||
#define preferences_face ((const watch_face_t){ \
|
||
preferences_face_setup, \
|
||
preferences_face_activate, \
|
||
preferences_face_loop, \
|
||
preferences_face_resign, \
|
||
NULL, \
|
||
})
|