[vert.glsl] #version 130 attribute vec3 in_Position; attribute vec4 in_Color; varying vec4 pass_Color; uniform mat4 u_projection; uniform mat4 u_view; uniform mat4 u_model; void main() { gl_Position = u_projection * u_view * u_model * vec4(in_Position, 1.0); pass_Color = in_Color; } [frag.glsl] #version 130 #if defined GL_ES precision highp float; #endif varying vec4 pass_Color; mat4 bayer = mat4( 0.0, 12.0, 3.0, 15.0, 8.0, 4.0, 11.0, 7.0, 2.0, 14.0, 1.0, 13.0, 10.0, 6.0, 9.0, 5.0); mat4 cluster = mat4(12.0, 5.0, 6.0, 13.0, 4.0, 0.0, 1.0, 7.0, 11.0, 3.0, 2.0, 8.0, 15.0, 10.0, 9.0, 14.0); float rand(vec2 p) { return fract(sin(dot(p, vec2(12.9898, 78.2333))) * 123.4567); } void main() { vec4 col = pass_Color; #if defined GL_ES int dx = int(mod(gl_FragCoord.x, 4.0)); int dy = int(mod(gl_FragCoord.y, 4.0)); float t; if (dx == 0) { if (dy == 0) t = cluster[0][0]; else if (dy == 1) t = cluster[0][1]; else if (dy == 2) t = cluster[0][2]; else t = cluster[0][3]; } else if (dx == 1) { if (dy == 0) t = cluster[1][0]; else if (dy == 1) t = cluster[1][1]; else if (dy == 2) t = cluster[1][2]; else t = cluster[1][3]; } else if (dx == 2) { if (dy == 0) t = cluster[2][0]; else if (dy == 1) t = cluster[2][1]; else if (dy == 2) t = cluster[2][2]; else t = cluster[2][3]; } else { if (dy == 0) t = cluster[3][0]; else if (dy == 1) t = cluster[3][1]; else if (dy == 2) t = cluster[3][2]; else t = cluster[3][3]; } #else float t = cluster[int(mod(gl_FragCoord.x, 4.0))] [int(mod(gl_FragCoord.y, 4.0))]; #endif t += rand(gl_FragCoord.xy) - 0.5; t = (t + 0.5) / 17.0; col.x += fract(t - col.x) - t; col.y += fract(t - col.y) - t; col.z += fract(t - col.z) - t; gl_FragColor = col; } [vert.hlsl] void main(float4 in_Vertex : POSITION, float4 in_Color : COLOR, uniform float4x4 u_projection, uniform float4x4 u_view, uniform float4x4 u_model, out float4 out_Color : COLOR, out float4 out_Position : POSITION) { out_Position = mul(u_projection, mul(u_view, mul(u_model, in_Vertex))); out_Color = in_Color; } [frag.hlsl] float4x4 bayer = float4x4( 0.0, 12.0, 3.0, 15.0, 8.0, 4.0, 11.0, 7.0, 2.0, 14.0, 1.0, 13.0, 10.0, 6.0, 9.0, 5.0); #if 1 float4x4 cluster = float4x4(12.0, 5.0, 6.0, 13.0, 4.0, 0.0, 1.0, 7.0, 11.0, 3.0, 2.0, 8.0, 15.0, 10.0, 9.0, 14.0); #endif void main(float4 in_Color : COLOR, float4 in_FragCoord : WPOS, out float4 out_FragColor : COLOR) { float4 col = in_Color; #if 1 int x = (int)in_FragCoord.x; int y = (int)in_FragCoord.y; // FIXME: we cannot address this matrix directly on the PS3 float t = bayer[int(frac(x * 0.25) * 4.0)] [int(frac(y * 0.25) * 4.0)]; t = (t + 0.5) / 17.0; col.x += frac(t - col.x) - t; col.y += frac(t - col.y) - t; col.z += frac(t - col.z) - t; #endif out_FragColor = col; }