2009-11-11 19:53:20 +08:00
|
|
|
uniform sampler2D texture;
|
2011-12-10 20:02:38 +08:00
|
|
|
uniform float edge_threshold;
|
2009-11-11 19:53:20 +08:00
|
|
|
|
|
|
|
void main()
|
|
|
|
{
|
|
|
|
const float offset = 1.0 / 512.0;
|
|
|
|
vec2 offx = vec2(offset, 0.0);
|
|
|
|
vec2 offy = vec2(0.0, offset);
|
|
|
|
|
|
|
|
vec4 hEdge = texture2D(texture, gl_TexCoord[0].xy - offy) * -2.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy + offy) * 2.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy - offx - offy) * -1.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy - offx + offy) * 1.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy + offx - offy) * -1.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy + offx + offy) * 1.0;
|
|
|
|
|
|
|
|
vec4 vEdge = texture2D(texture, gl_TexCoord[0].xy - offx) * 2.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy + offx) * -2.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy - offx - offy) * 1.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy - offx + offy) * -1.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy + offx - offy) * 1.0 +
|
|
|
|
texture2D(texture, gl_TexCoord[0].xy + offx + offy) * -1.0;
|
|
|
|
|
2009-11-12 15:44:11 +08:00
|
|
|
vec3 result = sqrt(hEdge.rgb * hEdge.rgb + vEdge.rgb * vEdge.rgb);
|
|
|
|
float edge = length(result);
|
2011-12-10 20:02:38 +08:00
|
|
|
vec4 pixel = gl_Color * texture2D(texture, gl_TexCoord[0].xy);
|
2011-12-14 14:34:47 +08:00
|
|
|
if (edge > (edge_threshold * 8.0))
|
2011-12-10 20:02:38 +08:00
|
|
|
pixel.rgb = vec3(0.0, 0.0, 0.0);
|
2009-11-11 19:53:20 +08:00
|
|
|
else
|
2011-12-10 20:02:38 +08:00
|
|
|
pixel.a = edge_threshold;
|
|
|
|
gl_FragColor = pixel;
|
2009-11-11 19:53:20 +08:00
|
|
|
}
|