summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVolker Grabsch <vog@notjusthosting.com>2010-05-13 22:21:49 (GMT)
committerVolker Grabsch <vog@notjusthosting.com>2010-05-13 22:21:49 (GMT)
commit37002560946248d9ced8b0d75ab94453b4e7f616 (patch)
tree54bede5dce9a4dab5616aaacec8d67eee264ee10
parent70d07bad9214eadc4b4594500cd9cfae2bbf3ced (diff)
downloadmxe-37002560946248d9ced8b0d75ab94453b4e7f616.zip
mxe-37002560946248d9ced8b0d75ab94453b4e7f616.tar.gz
mxe-37002560946248d9ced8b0d75ab94453b4e7f616.tar.bz2
test program for package gtkglext (by Martin Gerhardy)
-rw-r--r--src/gtkglext-test.c82
1 files changed, 82 insertions, 0 deletions
diff --git a/src/gtkglext-test.c b/src/gtkglext-test.c
new file mode 100644
index 0000000..d4f8c6f
--- /dev/null
+++ b/src/gtkglext-test.c
@@ -0,0 +1,82 @@
+/* This file is part of mingw-cross-env. */
+/* See doc/index.html for further information. */
+
+#include <gtk/gtk.h>
+#include <gtk/gtkgl.h>
+#include <GL/gl.h>
+
+static gboolean eventExpose(GtkWidget *gl, GdkEventExpose *e, gpointer userData)
+{
+ GdkGLContext *ctx = gtk_widget_get_gl_context(gl);
+ GdkGLDrawable *drawable = gtk_widget_get_gl_drawable(gl);
+
+ gdk_gl_drawable_gl_begin(drawable, ctx);
+
+ glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
+
+ if (!gdk_gl_drawable_is_double_buffered(drawable))
+ glFinish();
+ else
+ gdk_gl_drawable_swap_buffers(drawable);
+
+ gdk_gl_drawable_gl_end(drawable);
+
+ return TRUE;
+}
+
+static gboolean eventConfigure(GtkWidget *gl, GdkEventConfigure *e, gpointer userData)
+{
+ const guint width = gl->allocation.width;
+ const guint height = gl->allocation.height;
+
+ glLoadIdentity();
+ glViewport(0, 0, width, height);
+ glOrtho(-3.5, 3.5, -3.5 * (GLfloat)height / (GLfloat)width,
+ 3.5 * (GLfloat)height / (GLfloat)width, -3.5, 3.5);
+
+ return TRUE;
+}
+
+int main(int argc, char *argv[])
+{
+ GtkWidget* window;
+ GtkWidget* gl;
+ GdkGLConfig* glConfig;
+
+ gtk_init(&argc, &argv);
+ gtk_gl_init(&argc, &argv);
+
+ window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
+ gl = gtk_drawing_area_new();
+ gtk_container_add(GTK_CONTAINER(window), gl);
+
+ gtk_widget_set_events(gl, GDK_EXPOSURE_MASK);
+
+ glConfig = gdk_gl_config_new_by_mode(
+ GDK_GL_MODE_RGB |
+ GDK_GL_MODE_ALPHA |
+ GDK_GL_MODE_DEPTH |
+ GDK_GL_MODE_DOUBLE);
+
+ gtk_widget_set_gl_capability(gl, glConfig,
+ NULL, TRUE, GDK_GL_RGBA_TYPE);
+
+ g_signal_connect_swapped(
+ G_OBJECT(window), "destroy",
+ G_CALLBACK(gtk_main_quit), G_OBJECT(window));
+
+ g_signal_connect(
+ G_OBJECT(window), "destroy",
+ G_CALLBACK(gtk_main_quit), NULL);
+
+ g_signal_connect(gl, "configure-event",
+ G_CALLBACK(eventConfigure), NULL);
+
+ g_signal_connect(gl, "expose-event",
+ G_CALLBACK(eventExpose), NULL);
+
+ gtk_widget_show_all(window);
+
+ gtk_main();
+ return 0;
+}