mesa/progs/vpglsl/func2.glsl

54 lines
878 B
GLSL

#version 120
const int KernelSize = 16;
uniform float KernelValue1f[KernelSize];
float add_two(float a, float b)
{
if (a > b)
return a - b;
else
return a + b;
}
vec4 myfunc(vec4 x, vec4 mult, vec4 c)
{
if (x.x >= 0.5) {
return mult * c;
} else {
return mult + c;
}
}
vec4 func2(vec4 x)
{
int i;
vec4 color = vec4(0);
for (i = 0; i < KernelSize; ++i) {
vec4 tmp = vec4(1./KernelSize);
color += myfunc(x, tmp, gl_Color);
}
return x * color;
}
vec4 func(vec4 x)
{
int i;
vec4 tmp = gl_Color;
vec4 sum = x;
for (i = 0; i < KernelSize; ++i) {
sum = vec4( add_two(sum.x, KernelValue1f[i]) );
}
sum = func2(sum);
return sum;
}
void main(void)
{
vec4 sum = vec4(0.0);
sum = func(sum);
gl_Position = gl_Vertex;
gl_FrontColor = sum;
}