X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=src%2Faweather.c;h=380db65f3a4ed98ad4a1b8804a51c6e6f7d92f40;hb=051345150b2fad10610e18b7b4aa268551335a0e;hp=66808500177e671a3f908c3e309310aee575c1cd;hpb=6e2c2fee8cacb353d58fb10e489f45131d223826;p=grits diff --git a/src/aweather.c b/src/aweather.c index 6680850..380db65 100644 --- a/src/aweather.c +++ b/src/aweather.c @@ -3,7 +3,10 @@ #include #include -#include "cube.h" +#include "opengl.h" +#include "radar.h" +#include "ridge.h" +#include "example.h" static void destroy(GtkWidget *widget, gpointer data) { @@ -20,6 +23,7 @@ static gboolean key_press(GtkWidget *widget, GdkEventKey *event, gpointer data) { if (event->keyval == GDK_q) destroy(widget, data); + return TRUE; } int main(int argc, char *argv[]) @@ -32,12 +36,13 @@ int main(int argc, char *argv[]) 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), "delete-event", G_CALLBACK(delete_event), NULL); g_signal_connect(G_OBJECT(window), "key-press-event", G_CALLBACK(key_press), 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(); @@ -52,14 +57,30 @@ int main(int argc, char *argv[]) /* Set up darwing area */ GtkWidget *drawing = gtk_drawing_area_new(); - gtk_box_pack_start(GTK_BOX(vbox), drawing, TRUE, TRUE, 0); - //gtk_widget_set_events(drawing, GDK_EXPOSURE_MASK); // needed? - GdkGLConfig *glconfig = gdk_gl_config_new_by_mode(GDK_GL_MODE_RGB | GDK_GL_MODE_DEPTH | GDK_GL_MODE_DOUBLE); - if (!glconfig) g_assert_not_reached(); - if (!gtk_widget_set_gl_capability(drawing, glconfig, NULL, TRUE, GDK_GL_RGBA_TYPE)) g_assert_not_reached(); + 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); + 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 */ - cube_init(drawing); + opengl_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); + ridge_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); + radar_init (GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); + //example_init(GTK_DRAWING_AREA(drawing), GTK_NOTEBOOK(tab_area)); gtk_widget_show_all(window); gtk_main();