summaryrefslogtreecommitdiff
path: root/tests/gtkgears.c
diff options
context:
space:
mode:
authorEmmanuele Bassi <ebassi@gnome.org>2016-04-23 12:31:15 +0100
committerEmmanuele Bassi <ebassi@gnome.org>2016-04-25 14:35:02 +0100
commitb993c7db6362b013b1c0f7a9c8821b652b834e08 (patch)
treeafa2f805647813a99a45569dfe5707ca6fe0d7b9 /tests/gtkgears.c
parenta92ba06383ad7fe8bb63279603ceeee2ce6217f3 (diff)
downloadgtk+-b993c7db6362b013b1c0f7a9c8821b652b834e08.tar.gz
tests: Add GLES support to GtkGears
Use the appropriate GLSL shaders when running under an OpenGL ES context.
Diffstat (limited to 'tests/gtkgears.c')
-rw-r--r--tests/gtkgears.c54
1 files changed, 50 insertions, 4 deletions
diff --git a/tests/gtkgears.c b/tests/gtkgears.c
index a8e4fed812..d46f59876a 100644
--- a/tests/gtkgears.c
+++ b/tests/gtkgears.c
@@ -652,7 +652,7 @@ gtk_gears_render (GtkGLArea *area,
return TRUE;
}
-static const char vertex_shader[] =
+static const char vertex_shader_gl[] =
"#version 150\n"
"\n"
"in vec3 position;\n"
@@ -682,7 +682,7 @@ static const char vertex_shader[] =
" gl_Position = ModelViewProjectionMatrix * vec4(position, 1.0);\n"
"}";
-static const char fragment_shader[] =
+static const char fragment_shader_gl[] =
"#version 150\n"
"\n"
"smooth in vec4 Color;\n"
@@ -692,12 +692,50 @@ static const char fragment_shader[] =
" gl_FragColor = Color;\n"
"}";
+static const char vertex_shader_gles[] =
+"attribute vec3 position;\n"
+"attribute vec3 normal;\n"
+"\n"
+"uniform mat4 ModelViewProjectionMatrix;\n"
+"uniform mat4 NormalMatrix;\n"
+"uniform vec4 LightSourcePosition;\n"
+"uniform vec4 MaterialColor;\n"
+"\n"
+"varying vec4 Color;\n"
+"\n"
+"void main(void)\n"
+"{\n"
+" // Transform the normal to eye coordinates\n"
+" vec3 N = normalize(vec3(NormalMatrix * vec4(normal, 1.0)));\n"
+"\n"
+" // The LightSourcePosition is actually its direction for directional light\n"
+" vec3 L = normalize(LightSourcePosition.xyz);\n"
+"\n"
+" // Multiply the diffuse value by the vertex color (which is fixed in this case)\n"
+" // to get the actual color that we will use to draw this vertex with\n"
+" float diffuse = max(dot(N, L), 0.0);\n"
+" Color = diffuse * MaterialColor;\n"
+"\n"
+" // Transform the position to clip coordinates\n"
+" gl_Position = ModelViewProjectionMatrix * vec4(position, 1.0);\n"
+"}";
+
+static const char fragment_shader_gles[] =
+"precision mediump float;\n"
+"varying vec4 Color;\n"
+"\n"
+"void main(void)\n"
+"{\n"
+" gl_FragColor = Color;\n"
+"}";
+
static void
gtk_gears_realize (GtkWidget *widget)
{
GtkGLArea *glarea = GTK_GL_AREA (widget);
GtkGears *gears = GTK_GEARS (widget);
GtkGearsPrivate *priv = gtk_gears_get_instance_private (gears);
+ GdkGLContext *context;
GLuint vao, v, f, program;
const char *p;
char msg[512];
@@ -708,6 +746,8 @@ gtk_gears_realize (GtkWidget *widget)
if (gtk_gl_area_get_error (glarea) != NULL)
return;
+ context = gtk_gl_area_get_context (glarea);
+
glEnable (GL_CULL_FACE);
glEnable (GL_DEPTH_TEST);
@@ -717,7 +757,10 @@ gtk_gears_realize (GtkWidget *widget)
priv->vao = vao;
/* Compile the vertex shader */
- p = vertex_shader;
+ if (gdk_gl_context_get_use_es (context))
+ p = vertex_shader_gles;
+ else
+ p = vertex_shader_gl;
v = glCreateShader(GL_VERTEX_SHADER);
glShaderSource(v, 1, &p, NULL);
glCompileShader(v);
@@ -725,7 +768,10 @@ gtk_gears_realize (GtkWidget *widget)
g_print ("vertex shader info: %s\n", msg);
/* Compile the fragment shader */
- p = fragment_shader;
+ if (gdk_gl_context_get_use_es (context))
+ p = fragment_shader_gles;
+ else
+ p = fragment_shader_gl;
f = glCreateShader(GL_FRAGMENT_SHADER);
glShaderSource(f, 1, &p, NULL);
glCompileShader(f);