X-Git-Url: http://pileus.org/git/?p=grits;a=blobdiff_plain;f=src%2Faweather.c;h=a732eb26c9b24203c649e9875577034445c7dfea;hp=098102cfc16c995078b17a58cd7b9bbfd7ca9355;hb=a29b3442b18244050308606dd69265cd3fd7fdb7;hpb=f230908a4780fd954772bbc3d17658aba86baea8 diff --git a/src/aweather.c b/src/aweather.c index 098102c..a732eb2 100644 --- a/src/aweather.c +++ b/src/aweather.c @@ -8,21 +8,10 @@ #include "plugin-ridge.h" #include "plugin-example.h" -static void destroy(GtkWidget *widget, gpointer data) -{ - gtk_main_quit(); -} - -static gboolean delete_event(GtkWidget *widget, GdkEvent *event, gpointer data) -{ - destroy(widget, data); - return FALSE; -} - -static gboolean key_press(GtkWidget *widget, GdkEventKey *event, gpointer data) +gboolean on_window_key_press_event(GtkWidget *widget, GdkEventKey *event, gpointer data) { if (event->keyval == GDK_q) - destroy(widget, data); + gtk_main_quit(); return TRUE; } @@ -32,56 +21,33 @@ int main(int argc, char *argv[]) gtk_init(&argc, &argv); gtk_gl_init(&argc, &argv); - /* Set up window */ - GtkWidget *window = gtk_window_new(GTK_WINDOW_TOPLEVEL); - gtk_window_set_default_size(GTK_WINDOW(window), 800, 600); - g_signal_connect(G_OBJECT(window), "delete-event", G_CALLBACK(delete_event), NULL); - g_signal_connect(G_OBJECT(window), "key-press-event", G_CALLBACK(key_press), NULL); + GError *error = NULL; + GtkBuilder *builder = gtk_builder_new(); + if (!gtk_builder_add_from_file(builder, DATADIR "/aweather/aweather.xml", &error)) + g_error("Failed to create gtk builder: %s", error->message); + gtk_builder_connect_signals(builder, NULL); - /* Set up layout */ - GtkWidget *vbox = gtk_vbox_new(FALSE, 0); - gtk_container_add(GTK_CONTAINER(window), vbox); - GtkWidget *paned = gtk_vpaned_new(); - gtk_box_pack_end(GTK_BOX(vbox), paned, TRUE, TRUE, 0); - - /* Set up menu bar */ - GtkWidget *menu = gtk_menu_bar_new(); - GtkWidget *menu_file = gtk_menu_item_new_with_label("File"); - GtkWidget *menu_file_menu = gtk_menu_new(); - GtkWidget *menu_file_menu_quit = gtk_menu_item_new_with_label("Quit"); - gtk_box_pack_start(GTK_BOX(vbox), menu, FALSE, FALSE, 0); - gtk_menu_shell_append(GTK_MENU_SHELL(menu), menu_file); - gtk_menu_item_set_submenu(GTK_MENU_ITEM(menu_file), menu_file_menu); - gtk_menu_shell_append(GTK_MENU_SHELL(menu_file_menu), menu_file_menu_quit); - g_signal_connect(G_OBJECT(menu_file_menu_quit), "activate", G_CALLBACK(destroy), NULL); + GtkWidget *window = GTK_WIDGET(gtk_builder_get_object(builder, "window")); + GtkWidget *drawing = GTK_WIDGET(gtk_builder_get_object(builder, "drawing")); + GtkWidget *tabs = GTK_WIDGET(gtk_builder_get_object(builder, "tabs")); + if (window == NULL) g_error("window is null"); + if (drawing == NULL) g_error("drawing is null"); + if (tabs == NULL) g_error("tabs is null"); /* Set up darwing area */ - GtkWidget *drawing = gtk_drawing_area_new(); - gtk_paned_pack1(GTK_PANED(paned), drawing, TRUE, FALSE); - //gtk_box_pack_end(GTK_BOX(vbox), drawing, TRUE, TRUE, 0); GdkGLConfig *glconfig = gdk_gl_config_new_by_mode( - GDK_GL_MODE_RGBA | - GDK_GL_MODE_DEPTH | - GDK_GL_MODE_DOUBLE | - GDK_GL_MODE_ALPHA); + GDK_GL_MODE_RGBA | GDK_GL_MODE_DEPTH | + GDK_GL_MODE_DOUBLE | GDK_GL_MODE_ALPHA); if (!glconfig) g_assert_not_reached(); if (!gtk_widget_set_gl_capability(drawing, glconfig, NULL, TRUE, GDK_GL_RGBA_TYPE)) g_assert_not_reached(); - /* Set up tab area */ - GtkWidget *tab_area = gtk_notebook_new(); - gtk_notebook_set_tab_pos(GTK_NOTEBOOK(tab_area), GTK_POS_BOTTOM); - gtk_paned_pack2(GTK_PANED(paned), tab_area, FALSE, FALSE); - //GtkWidget *label = gtk_label_new("Hello"); - //GtkWidget *contents = gtk_label_new("World"); - //gtk_notebook_append_page(GTK_NOTEBOOK(tab_area), contents, label); - /* Load plugins */ - opengl_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); - radar_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); - ridge_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); - example_init(GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); + opengl_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tabs)); + radar_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tabs)); + ridge_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tabs)); + example_init(GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tabs)); gtk_widget_show_all(window); gtk_main();