This section covers various useful functions that don't fit anywhere else.
More...
|
const char * | watch_utility_get_weekday (watch_date_time date_time) |
| Returns a two-letter weekday for the given timestamp, suitable for display in positions 0-1 of the watch face. More...
|
|
uint32_t | watch_utility_convert_to_unix_time (uint16_t year, uint8_t month, uint8_t day, uint8_t hour, uint8_t minute, uint8_t second, uint32_t utc_offset) |
| Returns the UNIX time (seconds since 1970) for a given date/time in UTC. More...
|
|
uint32_t | watch_utility_date_time_to_unix_time (watch_date_time date_time, uint32_t utc_offset) |
| Returns the UNIX time (seconds since 1970) for a given watch_date_time struct. More...
|
|
watch_duration_t | watch_utility_seconds_to_duration (uint32_t seconds) |
| Converts a duration in seconds to a watch_duration_t struct. More...
|
|
watch_date_time | watch_utility_date_time_from_unix_time (uint32_t timestamp, uint32_t utc_offset) |
| Returns a watch_date_time struct for a given UNIX time and UTC offset. More...
|
|
bool | watch_utility_convert_to_12_hour (watch_date_time *date_time) |
| Converts a watch_date_time for 12-hour display. More...
|
|
watch_date_time | watch_utility_date_time_convert_zone (watch_date_time date_time, uint32_t origin_utc_offset, uint32_t destination_utc_offset) |
| Converts a time from a given time zone to another time zone. More...
|
|
float | watch_utility_thermistor_temperature (uint16_t value, bool highside, float b_coefficient, float nominal_temperature, float nominal_resistance, float series_resistance) |
| Returns a temperature in degrees Celsius for a given thermistor voltage divider circuit. More...
|
|
uint32_t | watch_utility_offset_timestamp (uint32_t now, int8_t hours, int8_t minutes, int8_t seconds) |
| Offset a timestamp by a given amount. More...
|
|
|
uint8_t | watch_duration_t::seconds |
|
uint8_t | watch_duration_t::minutes |
|
uint8_t | watch_duration_t::hours |
|
uint32_t | watch_duration_t::days |
|
This section covers various useful functions that don't fit anywhere else.
◆ watch_utility_convert_to_12_hour()
Converts a watch_date_time for 12-hour display.
- Parameters
-
date_time | A pointer to the watch_date_time that you wish to convert for display. Note that this function will OVERWRITE the original date/time, rendering it invalid for date/time calculations. Midnight (hour 0) will become 12, and hours in the afternoon will wrap back around to values from 1-11. |
- Returns
- True if the value is in the afternoon. You can use this value to determine whether to set the PM indicator on the LCD.
- Note
- This function sort of abuses the watch_date_time struct; the date/time that results from calling this function is clamped to the hours of 1:00:00 AM through 12:59:59 PM. It no longer reflects a valid watch_date_time for writing to an RTC register.
◆ watch_utility_convert_to_unix_time()
uint32_t watch_utility_convert_to_unix_time |
( |
uint16_t |
year, |
|
|
uint8_t |
month, |
|
|
uint8_t |
day, |
|
|
uint8_t |
hour, |
|
|
uint8_t |
minute, |
|
|
uint8_t |
second, |
|
|
uint32_t |
utc_offset |
|
) |
| |
Returns the UNIX time (seconds since 1970) for a given date/time in UTC.
- Parameters
-
date_time | The watch_date_time that you wish to convert. |
year | The year of the date you wish to convert. |
month | The month of the date you wish to convert. |
day | The day of the date you wish to convert. |
hour | The hour of the date you wish to convert. |
minute | The minute of the date you wish to convert. |
second | The second of the date you wish to convert. |
utc_offset | The number of seconds that date_time is offset from UTC, or 0 if the time is UTC. |
- Returns
- A UNIX timestamp for the given date/time and UTC offset.
- Note
- Implemented by Wesley Ellis (tahnok) and based on BSD-licensed code by Josh Haberman: https://blog.reverberate.org/2020/05/12/optimizing-date-algorithms.html
◆ watch_utility_date_time_convert_zone()
◆ watch_utility_date_time_from_unix_time()
watch_date_time watch_utility_date_time_from_unix_time |
( |
uint32_t |
timestamp, |
|
|
uint32_t |
utc_offset |
|
) |
| |
◆ watch_utility_date_time_to_unix_time()
uint32_t watch_utility_date_time_to_unix_time |
( |
watch_date_time |
date_time, |
|
|
uint32_t |
utc_offset |
|
) |
| |
Returns the UNIX time (seconds since 1970) for a given watch_date_time struct.
- Parameters
-
date_time | The watch_date_time that you wish to convert. |
utc_offset | The number of seconds that date_time is offset from UTC, or 0 if the time is UTC. |
- Returns
- A UNIX timestamp for the given watch_date_time and UTC offset.
◆ watch_utility_get_weekday()
Returns a two-letter weekday for the given timestamp, suitable for display in positions 0-1 of the watch face.
- Parameters
-
◆ watch_utility_offset_timestamp()
uint32_t watch_utility_offset_timestamp |
( |
uint32_t |
now, |
|
|
int8_t |
hours, |
|
|
int8_t |
minutes, |
|
|
int8_t |
seconds |
|
) |
| |
Offset a timestamp by a given amount.
- Parameters
-
now | Timestamp to offset from |
hours | Number of hours to offset |
minutes | Nmber of minutes to offset |
seconds | Number of secodns to offset |
◆ watch_utility_seconds_to_duration()
Converts a duration in seconds to a watch_duration_t struct.
- Parameters
-
seconds | A positive number of seconds that you wish to convert to a formatted duration. |
- Returns
- A populated struct with the number of days, hours, minutes and seconds elapsed.
◆ watch_utility_thermistor_temperature()
float watch_utility_thermistor_temperature |
( |
uint16_t |
value, |
|
|
bool |
highside, |
|
|
float |
b_coefficient, |
|
|
float |
nominal_temperature, |
|
|
float |
nominal_resistance, |
|
|
float |
series_resistance |
|
) |
| |
Returns a temperature in degrees Celsius for a given thermistor voltage divider circuit.
- Parameters
-
value | The raw analog reading from the thermistor pin (0-65535) |
highside | True if the thermistor is connected to VCC and the series resistor is connected to GND; false if the thermistor is connected to GND and the series resistor is connected to VCC. |
b_coefficient | From your thermistor's data sheet, the B25/85 coefficient. A typical value will be between 2000 and 5000. |
nominal_temperature | From your thermistor's data sheet, the temperature (in Celsius) at which the thermistor's resistance is at its nominal value. |
nominal_resistance | The thermistor's resistance at the nominal temperature. |
series_resistance | The value of the other resistor in the voltage divider. |
- Note
- Ported from Adafruit's MIT-licensed CircuitPython thermistor code, (c) 2017 Scott Shawcroft: https://github.com/adafruit/Adafruit_CircuitPython_Thermistor/blob/main/adafruit_thermistor.py