File: HorizontalMinimumEdgeDistanceShader.frag.txt

package info (click to toggle)
psychtoolbox-3 3.0.14.20170103%2Bgit6-g605ff5c.dfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 103,044 kB
  • ctags: 69,483
  • sloc: ansic: 167,371; cpp: 11,232; objc: 4,708; sh: 1,875; python: 383; php: 344; makefile: 207; java: 113
file content (35 lines) | stat: -rw-r--r-- 1,148 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/* HorizontalMinimumEdgeDistanceShader
 * Scans along a horizontal line in bound rectangle texture zero.
 * Detects the first steep increase in luminance between two
 * consecutive texels and writes its value and position into
 * the output fragment color.
 *
 * This shader computes the minimum distance to an intensity edge.
 * (w)2006 by Mario Kleiner. Licensed under MIT license.
*/

#extension GL_ARB_texture_rectangle : enable

const float threshold = 0.05;
const vec4 ColorToGrayWeights = { 0.3, 0.59, 0.11, 0.0 }; 
uniform sampler2DRect Image;

void main()
{
    vec4  leftcolor;
    vec4  rightcolor;
    float rlum, llum;
    int pos;
    float minposition = 1;

    for(pos = 0; pos<255; pos++) {
      leftcolor  = texture2DRect(Image, gl_TexCoord[0].st + vec2(pos, 0.0));
      rightcolor = texture2DRect(Image, gl_TexCoord[0].st + vec2(pos + 5.0, 0.0));
      llum = dot(leftcolor, ColorToGrayWeights);
      rlum = dot(rightcolor, ColorToGrayWeights);
	if ((llum - rlum) > threshold) minposition=min(minposition, pos/255.0);
    }

    gl_FragColor.a = 255.0;
    gl_FragColor.rgb = minposition;
}