X-Git-Url: http://pileus.org/git/?p=grits;a=blobdiff_plain;f=src%2Fopengl.c;h=c943c796b00a17b52d5beba7fc0b88462352cbf2;hp=f348d71a0d05e5d9f3f6077421c49c561ad36f85;hb=051345150b2fad10610e18b7b4aa268551335a0e;hpb=1398794a7901ac38c29856d6d08b5f9fac15ff1a diff --git a/src/opengl.c b/src/opengl.c index f348d71..c943c79 100644 --- a/src/opengl.c +++ b/src/opengl.c @@ -1,10 +1,13 @@ #include +#include #include #include #include +#include static gboolean expose_start(GtkWidget *da, GdkEventExpose *event, gpointer user_data) { + g_message("opengl:expose_start"); GdkGLContext *glcontext = gtk_widget_get_gl_context(da); GdkGLDrawable *gldrawable = gtk_widget_get_gl_drawable(da); @@ -19,7 +22,9 @@ static gboolean expose_start(GtkWidget *da, GdkEventExpose *event, gpointer user /* Plugins run stuff here */ static gboolean expose_end(GtkWidget *da, GdkEventExpose *event, gpointer user_data) { - GdkGLDrawable *gldrawable = gtk_widget_get_gl_drawable(da); + g_message("opengl:expose_end\n"); + + GdkGLDrawable *gldrawable = gdk_gl_drawable_get_current(); if (gdk_gl_drawable_is_double_buffered(gldrawable)) gdk_gl_drawable_swap_buffers(gldrawable); @@ -30,34 +35,60 @@ static gboolean expose_end(GtkWidget *da, GdkEventExpose *event, gpointer user_d return FALSE; } -static gboolean configure(GtkWidget *da, GdkEventConfigure *event, gpointer user_data) +static gboolean configure_start(GtkWidget *da, GdkEventConfigure *event, gpointer user_data) { - GdkGLContext *glcontext = gtk_widget_get_gl_context(da); + GdkGLContext *glcontext = gtk_widget_get_gl_context(da); GdkGLDrawable *gldrawable = gtk_widget_get_gl_drawable(da); if (!gdk_gl_drawable_gl_begin(gldrawable, glcontext)) g_assert_not_reached(); - glLoadIdentity(); - glViewport(0, 0, da->allocation.width, da->allocation.height); - glOrtho(-10,10,-10,10,-20050,10000); + + double width = da->allocation.width; + double height = da->allocation.height; + double dist = 500*1000; // 500 km + + /* Misc */ + glViewport(0, 0, width, height); glEnable(GL_BLEND); glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); + glClearColor(0.8f, 0.8f, 1.0f, 0.0f); + glColorMaterial(GL_FRONT_AND_BACK, GL_AMBIENT_AND_DIFFUSE); + + /* Depth test */ + glClearDepth(1.0); + glDepthFunc(GL_LEQUAL); + glEnable(GL_DEPTH_TEST); + + /* Perspective */ + glMatrixMode(GL_PROJECTION); + glLoadIdentity(); + double rad = atan(height/2*1000.0/dist); // 1px = 1000 meters + double deg = (rad*180)/M_PI; + gluPerspective(deg*2, width/height, 0.1f, 1000000000.0f); + + /* Camera position? */ + glMatrixMode(GL_MODELVIEW); + glLoadIdentity(); + glTranslatef(0.0, 0.0, -dist); + //glRotatef(-45, 1, 0, 0); - glScalef(10., 10., 10.); - - gdk_gl_drawable_gl_end(gldrawable); return FALSE; } +static gboolean configure_end(GtkWidget *da, GdkEventConfigure *event, gpointer user_data) +{ + GdkGLDrawable *gldrawable = gdk_gl_drawable_get_current(); + gdk_gl_drawable_gl_end(gldrawable); + return FALSE; +} gboolean opengl_init(GtkDrawingArea *drawing, GtkNotebook *config) { /* Set up OpenGL Stuff */ - g_signal_connect(drawing, "configure-event", G_CALLBACK(configure), NULL); - - //g_signal_connect(drawing, "expose-event", G_CALLBACK(expose), NULL); - g_signal_connect (drawing, "expose-event", G_CALLBACK(expose_start), NULL); - g_signal_connect_after(drawing, "expose-event", G_CALLBACK(expose_end), NULL); + g_signal_connect (drawing, "configure-event", G_CALLBACK(configure_start), NULL); + g_signal_connect_after(drawing, "configure-event", G_CALLBACK(configure_end), NULL); + g_signal_connect (drawing, "expose-event", G_CALLBACK(expose_start), NULL); + g_signal_connect_after(drawing, "expose-event", G_CALLBACK(expose_end), NULL); return TRUE; }