9 #include <sys/socket.h>
15 //#include "Fonts.h" // the MetaWatch fonts
17 #include "oswald_main.h"
19 #include "oswald-ui.h"
21 #define BITMAP_WIDTH 192
22 #define BITMAP_HEIGHT 192
24 static oswald_ui *ui_g;
26 void hal_lcd_set_pixel(gint x, gint y, gboolean state)
33 gdk_draw_point(GDK_DRAWABLE(ui_g->pixmap), state ? ui_g->darea->style->black_gc : ui_g->darea->style->white_gc, ix, iy);
34 gdk_draw_point(GDK_DRAWABLE(ui_g->pixmap), state ? ui_g->darea->style->black_gc : ui_g->darea->style->white_gc, ix+1, iy);
35 gdk_draw_point(GDK_DRAWABLE(ui_g->pixmap), state ? ui_g->darea->style->black_gc : ui_g->darea->style->white_gc, ix, iy+1);
36 gdk_draw_point(GDK_DRAWABLE(ui_g->pixmap), state ? ui_g->darea->style->black_gc : ui_g->darea->style->white_gc, ix+1, iy+1);
40 /* updates the actual LCD so that drawing becomes visible */
41 void hal_lcd_update_display(void)
43 gtk_widget_queue_draw(ui_g->darea);
46 void hal_lcd_clear_display(void)
48 gdk_draw_rectangle (ui_g->pixmap,
49 ui_g->darea->style->white_gc,
52 ui_g->darea->allocation.width,
53 ui_g->darea->allocation.height);
55 gtk_widget_queue_draw(ui_g->darea);
58 static bluetooth_state bt_state = BLUETOOTH_OFF;
59 static boolean bt_visible = FALSE;
61 bluetooth_state hal_bluetooth_set_state(bluetooth_state state)
64 if (bt_state == BLUETOOTH_OFF)
70 bluetooth_state hal_bluetooth_get_state(void)
75 uint8_t *hal_bluetooth_get_local_bdaddr(void)
77 static uint8_t local_bdaddr[6] = {0x00, 0x11, 0x22, 0x33, 0x44, 0x55};
82 void hal_bluetooth_set_visible(boolean visible)
87 boolean hal_bluetooth_get_visible(void)
92 void hal_bluetooth_send_data(const void *mdat, uint16_t mlen)
94 g_printerr("write comm %d\n", mlen);
97 const char *hal_get_version_string(void)
102 const char *hal_get_buildno_string(void)
107 const char *hal_get_radio_version_string(void)
114 configure_event (GtkWidget *widget, GdkEventConfigure *event, gpointer user_data)
116 oswald_ui *ui = (oswald_ui *)user_data;
119 gdk_pixmap_unref(ui->pixmap);
121 ui->pixmap = gdk_pixmap_new(widget->window,
122 widget->allocation.width,
123 widget->allocation.height,
125 gdk_draw_rectangle (ui->pixmap,
126 widget->style->white_gc,
129 widget->allocation.width,
130 widget->allocation.height);
136 expose_event (GtkWidget *widget, GdkEventExpose *event, gpointer user_data)
138 oswald_ui *ui = (oswald_ui *)user_data;
140 gdk_draw_pixmap(widget->window,
141 widget->style->fg_gc[GTK_WIDGET_STATE (widget)],
143 event->area.x, event->area.y,
144 event->area.x, event->area.y,
145 event->area.width, event->area.height);
150 void button_A_clicked (GtkButton *button, gpointer user_data)
152 oswald_ui *ui = (oswald_ui *)user_data;
154 // g_print("Button-A clicked\n");
155 oswald_handle_button_press(BUTTON_A);
158 void button_B_clicked (GtkButton *button, gpointer user_data)
160 oswald_ui *ui = (oswald_ui *)user_data;
162 // g_print("Button-B clicked\n");
163 oswald_handle_button_press(BUTTON_B);
166 void button_C_clicked (GtkButton *button, gpointer user_data)
168 oswald_ui *ui = (oswald_ui *)user_data;
170 // g_print("Button-C clicked\n");
171 oswald_handle_button_press(BUTTON_C);
174 void button_D_clicked (GtkButton *button, gpointer user_data)
176 oswald_ui *ui = (oswald_ui *)user_data;
178 // g_print("Button-D clicked\n");
179 oswald_handle_button_press(BUTTON_D);
182 void button_E_clicked (GtkButton *button, gpointer user_data)
184 oswald_ui *ui = (oswald_ui *)user_data;
186 // g_print("Button-E clicked\n");
187 oswald_handle_button_press(BUTTON_E);
190 void button_F_clicked (GtkButton *button, gpointer user_data)
192 oswald_ui *ui = (oswald_ui *)user_data;
194 // g_print("Button-F clicked\n");
195 oswald_handle_button_press(BUTTON_F);
198 gboolean button_F_pr (GtkWidget *widget, GdkEvent *event, gpointer user_data)
200 oswald_ui *ui = (oswald_ui *)user_data;
201 static gint32 press_time;
203 GdkEventButton *bev = (GdkEventButton *)event;
204 if (bev->type == GDK_BUTTON_PRESS) {
205 press_time = bev->time;
208 if (bev->type == GDK_BUTTON_RELEASE) {
209 if (bev->time > (press_time+1000)) {
210 g_print("Button-F long press\n");
218 void ambientlight_value_changed (GtkRange *range, gpointer user_data)
220 oswald_ui *ui = (oswald_ui *)user_data;
223 val = gtk_range_get_value(range);
224 oswald_handle_ambientlight_event((uint8_t) val);
227 void accelX_value_changed (GtkRange *range, gpointer user_data)
229 oswald_ui *ui = (oswald_ui *)user_data;
232 val = gtk_range_get_value(range);
233 ui->accel_x = (uint8_t)val;
234 oswald_handle_accel_event(ui->accel_x, ui->accel_y, ui->accel_z);
237 void accelY_value_changed (GtkRange *range, gpointer user_data)
239 oswald_ui *ui = (oswald_ui *)user_data;
242 val = gtk_range_get_value(range);
243 ui->accel_y = (uint8_t)val;
244 oswald_handle_accel_event(ui->accel_x, ui->accel_y, ui->accel_z);
247 void accelZ_value_changed (GtkRange *range, gpointer user_data)
249 oswald_ui *ui = (oswald_ui *)user_data;
252 val = gtk_range_get_value(range);
253 ui->accel_z = (uint8_t)val;
254 oswald_handle_accel_event(ui->accel_x, ui->accel_y, ui->accel_z);
257 static void create_mainwin(oswald_ui *ui)
259 GtkWidget *mvb, *hb, *vb, *btn, *sc, *l;
263 ui->mainwin = gtk_window_new (GTK_WINDOW_TOPLEVEL);
264 // gtk_window_set_default_size (GTK_WINDOW (ui->mainwin), 440, 240);
265 g_signal_connect(G_OBJECT(ui->mainwin), "destroy", gtk_main_quit, NULL);
267 mvb = gtk_vbox_new(FALSE, 5);
268 gtk_container_add(GTK_CONTAINER(ui->mainwin), mvb);
270 hb = gtk_hbox_new(FALSE, 5);
271 gtk_box_pack_start (GTK_BOX(mvb), hb, FALSE, FALSE, 5);
273 vb = gtk_vbox_new(FALSE, 5);
274 gtk_box_pack_start (GTK_BOX(hb), vb, FALSE, FALSE, 5);
276 btn = gtk_button_new_with_label(" F ");
277 gtk_box_pack_start (GTK_BOX(vb), btn, FALSE, FALSE, 10);
278 g_signal_connect(G_OBJECT(btn), "clicked", G_CALLBACK(button_F_clicked), ui);
279 g_signal_connect(G_OBJECT(btn), "button-press-event", G_CALLBACK(button_F_pr), ui);
280 g_signal_connect(G_OBJECT(btn), "button-release-event", G_CALLBACK(button_F_pr), ui);
282 btn = gtk_button_new_with_label(" E ");
283 gtk_box_pack_start (GTK_BOX(vb), btn, FALSE, FALSE, 10);
284 g_signal_connect(G_OBJECT(btn), "clicked", G_CALLBACK(button_E_clicked), ui);
286 btn = gtk_button_new_with_label(" D ");
287 gtk_box_pack_start (GTK_BOX(vb), btn, FALSE, FALSE, 10);
288 g_signal_connect(G_OBJECT(btn), "clicked", G_CALLBACK(button_D_clicked), ui);
290 ui->darea = gtk_drawing_area_new ();
291 gtk_box_pack_start (GTK_BOX(hb), GTK_WIDGET(ui->darea), FALSE, FALSE, 5);
292 gtk_drawing_area_size (GTK_DRAWING_AREA(ui->darea), BITMAP_WIDTH, BITMAP_HEIGHT);
294 gtk_signal_connect (GTK_OBJECT (ui->darea), "expose_event", (GtkSignalFunc) expose_event, ui);
295 gtk_signal_connect (GTK_OBJECT (ui->darea), "configure_event", (GtkSignalFunc) configure_event, ui);
296 // gtk_signal_connect (GTK_OBJECT (drawing_area), "motion_notify_event", (GtkSignalFunc) motion_notify_event, ui);
297 // gtk_signal_connect (GTK_OBJECT (drawing_area), "button_press_event", (GtkSignalFunc) button_press_event, ui);
299 gtk_widget_set_events (GTK_WIDGET(ui->darea), GDK_EXPOSURE_MASK
300 | GDK_LEAVE_NOTIFY_MASK
301 | GDK_BUTTON_PRESS_MASK
302 | GDK_POINTER_MOTION_MASK
303 | GDK_POINTER_MOTION_HINT_MASK);
305 vb = gtk_vbox_new(FALSE, 5);
306 gtk_box_pack_start (GTK_BOX(hb), vb, FALSE, FALSE, 5);
308 btn = gtk_button_new_with_label(" A ");
309 gtk_box_pack_start (GTK_BOX(vb), btn, FALSE, FALSE, 10);
310 g_signal_connect(G_OBJECT(btn), "clicked", G_CALLBACK(button_A_clicked), ui);
312 btn = gtk_button_new_with_label(" B ");
313 gtk_box_pack_start (GTK_BOX(vb), btn, FALSE, FALSE, 10);
314 g_signal_connect(G_OBJECT(btn), "clicked", G_CALLBACK(button_B_clicked), ui);
316 btn = gtk_button_new_with_label(" C ");
317 gtk_box_pack_start (GTK_BOX(vb), btn, FALSE, FALSE, 10);
318 g_signal_connect(G_OBJECT(btn), "clicked", G_CALLBACK(button_C_clicked), ui);
320 // ambient light sensor
321 sc = gtk_vscale_new_with_range (0, 255, 1);
322 gtk_box_pack_start (GTK_BOX(hb), sc, FALSE, FALSE, 5);
323 g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(ambientlight_value_changed), ui);
325 hb = gtk_hbox_new(FALSE, 0);
326 gtk_box_pack_start (GTK_BOX(mvb), hb, FALSE, FALSE, 5);
328 l = gtk_label_new("X:");
329 gtk_box_pack_start (GTK_BOX(hb), l, FALSE, FALSE, 5);
330 sc = gtk_hscale_new_with_range (-128, 127, 1);
331 gtk_box_pack_start (GTK_BOX(hb), sc, TRUE, TRUE, 5);
332 g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(accelX_value_changed), ui);
334 l = gtk_label_new("Y:");
335 gtk_box_pack_start (GTK_BOX(hb), l, FALSE, FALSE, 5);
336 sc = gtk_hscale_new_with_range (-128, 127, 1);
337 gtk_box_pack_start (GTK_BOX(hb), sc, TRUE, TRUE, 5);
338 g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(accelY_value_changed), ui);
340 l = gtk_label_new("Z:");
341 gtk_box_pack_start (GTK_BOX(hb), l, FALSE, FALSE, 5);
342 sc = gtk_hscale_new_with_range (-128, 127, 1);
343 gtk_box_pack_start (GTK_BOX(hb), sc, TRUE, TRUE, 5);
344 g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(accelZ_value_changed), ui);
346 gtk_widget_show_all(ui->mainwin);
349 static gboolean one_second_tmo_handler (gpointer userdata)
351 oswald_ui *ui = (oswald_ui *)userdata;
353 oswald_one_second_tick();
358 static gboolean app_idle_handler (gpointer user_data)
361 if (OswaldState.pending_idle) {
362 // call Oswald's idle function
368 static gboolean centisecond_tmo_handler (gpointer userdata)
370 oswald_ui *ui = (oswald_ui *)userdata;
372 if (ui->centisecond_active)
373 oswald_centisecond_tick();
380 void hal_enable_centisecond_timer(void)
382 ui_g->centisecond_active = TRUE;
383 g_timeout_add(10, centisecond_tmo_handler, ui_g);
386 void hal_disable_centisecond_timer(void)
388 ui_g->centisecond_active = FALSE;
391 static gboolean halfsecond_tmo_handler (gpointer userdata)
393 oswald_ui *ui = (oswald_ui *)userdata;
395 if (ui->halfsecond_active)
396 oswald_halfsecond_tick();
403 void hal_enable_halfsecond_timer(void)
405 ui_g->halfsecond_active = TRUE;
406 g_timeout_add(500, halfsecond_tmo_handler, ui_g);
409 void hal_disable_halfsecond_timer(void)
411 ui_g->halfsecond_active = FALSE;
414 void hal_get_rtc(clock_state *rtc)
420 localtime_r(&mt, &mtime);
422 rtc->hour = mtime.tm_hour;
423 rtc->minute = mtime.tm_min;
424 rtc->second = mtime.tm_sec;
425 rtc->day = mtime.tm_mday;
426 rtc->month = (mtime.tm_mon + 1);
427 rtc->year = (mtime.tm_year + 1900);
430 void hal_set_rtc(const clock_state *rtc, boolean set_set)
434 void hal_get_power_state(power_state *pwr)
438 static boolean BacklightState = FALSE;
440 /* sets the backlight on/off, on=TRUE, off=FALSE */
441 void hal_lcd_set_backlight(boolean state)
443 g_print("turn LCD backlight %s\n", state ? "on" : "off");
444 BacklightState = state;
447 boolean hal_lcd_get_backlight(void)
449 return BacklightState;
453 /* sets the vibration motor on/off, on=TRUE, off=FALSE */
454 void hal_vibration_set_state(boolean state)
458 boolean hal_vibration_get_state(void)
464 int main(int argc , char ** argv)
475 ui.halfsecond_active = FALSE;
476 ui.centisecond_active = FALSE;
479 localtime_r(&mt, &mtime);
481 gtk_init (&argc, &argv);
484 gtk_widget_realize(ui.mainwin);
486 oswald_set_time(mtime.tm_hour, mtime.tm_min, mtime.tm_sec, TRUE);
487 oswald_set_date(mtime.tm_mday, (mtime.tm_mon + 1), (mtime.tm_year + 1900), TRUE);
490 g_timeout_add_seconds(1, one_second_tmo_handler, &ui);
491 // g_idle_add(app_idle_handler, &ui);