summaryrefslogtreecommitdiffstats
path: root/movement/watch_faces/settings/preferences_face.h
blob: c8f36d75ea0245638592519b3ba295eb99dd4ca6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/*
 * MIT License
 *
 * Copyright (c) 2022 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.
 */

#ifndef PREFERENCES_FACE_H_
#define PREFERENCES_FACE_H_

/*
 * PREFERENCES face
 *
 * 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.
 *
 *  BT - Button tone.
 *      This setting is only relevant if you installed the buzzer connector,
 *      and it toggles the beep when changing modes. If Y, the buzzer will
 *      sound a tone when Mode is pressed. Change to N to make the Mode
 *      button silent.
 *
 *  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"

void preferences_face_setup(movement_settings_t *settings, uint8_t watch_face_index, void ** context_ptr);
void preferences_face_activate(movement_settings_t *settings, void *context);
bool preferences_face_loop(movement_event_t event, movement_settings_t *settings, void *context);
void preferences_face_resign(movement_settings_t *settings, void *context);

#define preferences_face ((const watch_face_t){ \
    preferences_face_setup, \
    preferences_face_activate, \
    preferences_face_loop, \
    preferences_face_resign, \
    NULL, \
})

#endif // PREFERENCES_FACE_H_