]> git.karo-electronics.de Git - oswald.git/blobdiff - ui/oswald-ui.c
Countless fixes and enhancements
[oswald.git] / ui / oswald-ui.c
index a89523b3ad27c9734ca4347c8333f0c3f7b1cf16..37da1c092fdf12633cfde9a7b917cefa96d1e4b3 100644 (file)
@@ -155,6 +155,45 @@ gboolean button_F_pr (GtkWidget *widget, GdkEvent *event, gpointer user_data)
        return FALSE;
 }
 
+void ambientlight_value_changed (GtkRange *range, gpointer  user_data)
+{
+       oswald_ui *ui = (oswald_ui *)user_data;
+       double val;
+
+       val = gtk_range_get_value(range);
+       oswald_handle_ambientlight_event((u8t) val);
+}
+
+void accelX_value_changed (GtkRange *range, gpointer  user_data)
+{
+       oswald_ui *ui = (oswald_ui *)user_data;
+       double val;
+
+       val = gtk_range_get_value(range);
+       ui->accel_x = (u8t)val;
+       oswald_handle_accel_event(ui->accel_x, ui->accel_y, ui->accel_z);
+}
+
+void accelY_value_changed (GtkRange *range, gpointer  user_data)
+{
+       oswald_ui *ui = (oswald_ui *)user_data;
+       double val;
+
+       val = gtk_range_get_value(range);
+       ui->accel_y = (u8t)val;
+       oswald_handle_accel_event(ui->accel_x, ui->accel_y, ui->accel_z);
+}
+
+void accelZ_value_changed (GtkRange *range, gpointer  user_data)
+{
+       oswald_ui *ui = (oswald_ui *)user_data;
+       double val;
+
+       val = gtk_range_get_value(range);
+       ui->accel_z = (u8t)val;
+       oswald_handle_accel_event(ui->accel_x, ui->accel_y, ui->accel_z);
+}
+
 static void create_mainwin(oswald_ui *ui)
 {
        GtkWidget *mvb, *hb, *vb, *btn, *sc, *l;
@@ -218,8 +257,10 @@ static void create_mainwin(oswald_ui *ui)
        gtk_box_pack_start (GTK_BOX(vb), btn, FALSE, FALSE, 10);
        g_signal_connect(G_OBJECT(btn), "clicked", G_CALLBACK(button_C_clicked), ui);
 
+       // ambient light sensor
        sc = gtk_vscale_new_with_range (0, 255, 1);
        gtk_box_pack_start (GTK_BOX(hb), sc, FALSE, FALSE, 5);
+       g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(ambientlight_value_changed), ui);
 
        hb = gtk_hbox_new(FALSE, 0);
        gtk_box_pack_start (GTK_BOX(mvb), hb, FALSE, FALSE, 5);
@@ -228,21 +269,24 @@ static void create_mainwin(oswald_ui *ui)
        gtk_box_pack_start (GTK_BOX(hb), l, FALSE, FALSE, 5);
        sc = gtk_hscale_new_with_range (0, 255, 1);
        gtk_box_pack_start (GTK_BOX(hb), sc, TRUE, TRUE, 5);
+       g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(accelX_value_changed), ui);
 
        l = gtk_label_new("Y:");
        gtk_box_pack_start (GTK_BOX(hb), l, FALSE, FALSE, 5);
        sc = gtk_hscale_new_with_range (0, 255, 1);
        gtk_box_pack_start (GTK_BOX(hb), sc, TRUE, TRUE, 5);
+       g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(accelY_value_changed), ui);
 
        l = gtk_label_new("Z:");
        gtk_box_pack_start (GTK_BOX(hb), l, FALSE, FALSE, 5);
        sc = gtk_hscale_new_with_range (0, 255, 1);
        gtk_box_pack_start (GTK_BOX(hb), sc, TRUE, TRUE, 5);
+       g_signal_connect(G_OBJECT(sc), "value-changed", G_CALLBACK(accelZ_value_changed), ui);
 
        gtk_widget_show_all(ui->mainwin);
 }
 
-gboolean one_second_tmo_handler (gpointer userdata)
+static gboolean one_second_tmo_handler (gpointer userdata)
 {
        oswald_ui *ui = (oswald_ui *)userdata;
 
@@ -251,7 +295,7 @@ gboolean one_second_tmo_handler (gpointer userdata)
        return TRUE;
 }
 
-gboolean app_idle_handler (gpointer user_data)
+static gboolean app_idle_handler (gpointer user_data)
 {
        g_print("i");
        if (OswaldState.pending_idle) {
@@ -261,6 +305,52 @@ gboolean app_idle_handler (gpointer user_data)
        return FALSE;
 }
 
+static gboolean centisecond_tmo_handler (gpointer userdata)
+{
+       oswald_ui *ui = (oswald_ui *)userdata;
+
+       if (ui->centisecond_active)
+               oswald_centisecond_tick();
+       else
+               return FALSE;
+
+       return TRUE;
+}
+
+void enable_centisecond_timer(void)
+{
+       ui_g->centisecond_active = TRUE;
+       g_timeout_add(10, centisecond_tmo_handler, ui_g);
+}
+
+void disable_centisecond_timer(void)
+{
+       ui_g->centisecond_active = FALSE;
+}
+
+static gboolean halfsecond_tmo_handler (gpointer userdata)
+{
+       oswald_ui *ui = (oswald_ui *)userdata;
+
+       if (ui->halfsecond_active)
+               oswald_halfsecond_tick();
+       else
+               return FALSE;
+
+       return TRUE;
+}
+
+void enable_halfsecond_timer(void)
+{
+       ui_g->halfsecond_active = TRUE;
+       g_timeout_add(500, halfsecond_tmo_handler, ui_g);
+}
+
+void disable_halfsecond_timer(void)
+{
+       ui_g->halfsecond_active = FALSE;
+}
+
 int main(int argc , char ** argv)
 {
        oswald_ui ui;
@@ -269,6 +359,12 @@ int main(int argc , char ** argv)
 
        ui_g = &ui;
 
+       ui.accel_x = 0;
+       ui.accel_y = 0;
+       ui.accel_z = 0;
+       ui.halfsecond_active = FALSE;
+       ui.centisecond_active = FALSE;
+
        mt = time(NULL);
        localtime_r(&mt, &mtime);
 
@@ -277,7 +373,8 @@ int main(int argc , char ** argv)
        create_mainwin(&ui);
        gtk_widget_realize(ui.mainwin);
 
-       oswald_set_time(mtime.tm_hour, mtime.tm_min, mtime.tm_sec);
+       oswald_set_time(mtime.tm_hour, mtime.tm_min, mtime.tm_sec, TRUE);
+       oswald_set_date(mtime.tm_mday, (mtime.tm_mon + 1), (mtime.tm_year + 1900), TRUE);
        oswald_init();
 
        g_timeout_add_seconds(1, one_second_tmo_handler, &ui);