]> git.karo-electronics.de Git - oswald.git/blobdiff - ui/oswald.h
Add version information and info screen, some more work on the accel screen
[oswald.git] / ui / oswald.h
index 9a341e38e2d1a9d9dc6a68f0308825bcf3b5bbcf..8d16b2e3b01b8f9f6f7c6d67264dd73c564f6324 100644 (file)
@@ -1,5 +1,10 @@
 #ifndef _OSWALD_H
 #define _OSWALD_H
+#include <stdio.h>
+#include <string.h>
+#include <stdint.h>
+
+#define OSWALD_VERSION "v0.3"
 
 //#define DEBUG 1
 #ifdef DEBUG
@@ -8,11 +13,7 @@
 #define dbg_out( args... ) do {} while (0)
 #endif
 
-typedef signed char s8t;
-typedef unsigned char u8t;
-typedef signed short s16t;
-typedef unsigned short u16t;
-typedef u8t boolean;
+typedef uint8_t boolean;
 #ifdef TRUE
 #undef TRUE
 #endif
@@ -26,24 +27,42 @@ typedef u8t boolean;
 #endif
 
 typedef struct {
-       u8t     hour;
-       u8t     minute;
-       u8t     second;
-       u8t     day;
-       u8t     month;
-       u16t    year;
+       uint8_t hour;
+       uint8_t minute;
+       uint8_t second;
+       uint8_t day;
+       uint8_t wday; // day in week, 0=sunday, 1=monday,...
+       uint8_t month;
+       uint16_t        year;
        boolean clk24hr;
        boolean day_first;
 } clock_state;
 
+#define WDAY_SUNDAY    (1 << 0)
+#define WDAY_MONDAY    (1 << 1)
+#define WDAY_TUESDAY   (1 << 2)
+#define WDAY_WEDNESDAY (1 << 3)
+#define WDAY_THURSDAY  (1 << 4)
+#define WDAY_FRIDAY    (1 << 5)
+#define WDAY_SATURDAY  (1 << 6)
+typedef struct {
+       uint8_t hour;
+       uint8_t minute;
+       uint8_t wday; // bitfield 0 to 6, 1=sunday, 2=monday, 4=tuesday...
+} alarm_clk;
+
 typedef enum {
        IDLE_SCREEN = 0,
-       ACCEL_DISPLAY_SCREEN,
-       MENU_TEST_SCREEN,
+       ALARM_SETUP_SCREEN,
        STOP_WATCH_SCREEN,
-//     APPLICATION_SCREEN,
+       BLUETOOTH_SCREEN,
+       ACCEL_DISPLAY_SCREEN,
+       INFO_SCREEN,
        LAST_SCREEN,            // a marker for the last (not valid) screen)
+       MENU_TEST_SCREEN,
+       APPLICATION_SCREEN,
        DATETIME_SETTING_SCREEN,
+       ALARM_SCREEN,
        SCREENS_END,
 } screen_number;
 
@@ -66,10 +85,17 @@ typedef enum {
 #define EVENT_AMBIENTLIGHT_UPDATE      (1<<7)          // ambient light sensor updates
 #define EVENT_POWER_CHANGE             (1<<8)          // power source status change
 #define EVENT_COMMS                    (1<<9)          // communication, like Bluetooth I/O
+#define EVENT_POWER_STATE              (1<<10)         // power source changed or similar
+
+typedef enum {
+       EVENT_RET_UNHANDLED = 0,
+       EVENT_RET_HANDLED,
+       EVENT_RET_ERR
+} event_ret_t;
 
 typedef struct {
-       u16t event_mask;                                // the event the screen wants to receive
-       void (*event_func)(u16t event, void *data);     // callback for events
+       uint16_t event_mask;                            // the event the screen wants to receive
+       event_ret_t (*event_func)(uint16_t event, void *data);  // callback for events
        void *user_data;
 } watch_screen;
 
@@ -80,10 +106,31 @@ typedef struct {
 } watch_state;
 
 typedef struct {
-       u8t     x;
-       u8t     y;
-       u8t     z;
+       int8_t  x;
+       int8_t  y;
+       int8_t  z;
 } accel_data_t;
 
-#endif
+#define POWER_SOURCE_BATTERY   0
+#define POWER_SOURCE_EXTERNAL  1
+
+#define POWER_CHARGER_DONE     0
+#define POWER_CHARGER_PRECHARGE        1
+#define POWER_CHARGER_CHARGING 2
+#define POWER_CHARGER_UNK      3
+
+typedef struct {
+       uint8_t source;
+       uint8_t charge_state;
+       uint8_t percent;
+       uint16_t        level;
+} power_state;
+
+typedef enum {
+       BLUETOOTH_OFF = 0,
+       BLUETOOTH_ON,
+       BLUETOOTH_CONNECTED,
+       BLUETOOTH_ILL
+} bluetooth_state;
 
+#endif