* Move from .c to .h as needed for consistency. * When missing from both, copy from pull request or wiki. * When missing entirely, infer functionality from source code.
76 lines
3.0 KiB
C
76 lines
3.0 KiB
C
/*
|
||
* 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 BLINKY_FACE_H_
|
||
#define BLINKY_FACE_H_
|
||
|
||
/*
|
||
* BLINKY LIGHT face
|
||
*
|
||
* The blinky light watch face was designed as a tutorial for making a watch
|
||
* face in Movement, but it actually might be useful to have a blinking light
|
||
* in a pinch.
|
||
*
|
||
* The screen displays the name of the watch face (”BL”), as well as an S at
|
||
* the top right for slow blink or an F for fast blink. The bottom line selects
|
||
* the color: green, red or yellow. You can change the speed of the blinking
|
||
* light by pressing the Alarm button, and change the color with the Light
|
||
* button. A long press on the Alarm button starts the blinking light, and
|
||
* another long press stops it.
|
||
*
|
||
* Note that this will chew through your battery! The green LED uses about
|
||
* 450µA at full brightness, which is 45 times the normal power consumption of
|
||
* the watch. The red LED is an order of magnitude less efficient (4500 µA),
|
||
* and the yellow setting lights both LEDs, which chews through nearly
|
||
* 5 milliamperes. This means that one hour of yellow blinking is likely to
|
||
* eat up between 2 and 3 percent of the battery’s usable life!
|
||
*
|
||
* Still, if you need to signal your location to someone in a dark forest,
|
||
* this watch face could come in handy. Just try to use the green LED as much
|
||
* as you can.
|
||
*/
|
||
|
||
#include "movement.h"
|
||
|
||
typedef struct {
|
||
bool active;
|
||
bool fast;
|
||
uint8_t color;
|
||
} blinky_face_state_t;
|
||
|
||
void blinky_face_setup(movement_settings_t *settings, uint8_t watch_face_index, void ** context_ptr);
|
||
void blinky_face_activate(movement_settings_t *settings, void *context);
|
||
bool blinky_face_loop(movement_event_t event, movement_settings_t *settings, void *context);
|
||
void blinky_face_resign(movement_settings_t *settings, void *context);
|
||
|
||
#define blinky_face ((const watch_face_t){ \
|
||
blinky_face_setup, \
|
||
blinky_face_activate, \
|
||
blinky_face_loop, \
|
||
blinky_face_resign, \
|
||
NULL, \
|
||
})
|
||
|
||
#endif // BLINKY_FACE_H_
|