forked from patriciogonzalezvivo/lygia_examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
filter_gaussianBlur1D.frag
40 lines (27 loc) · 952 Bytes
/
filter_gaussianBlur1D.frag
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
36
37
38
39
40
#ifdef GL_ES
precision mediump float;
#endif
uniform vec2 u_resolution;
uniform float u_time;
uniform sampler2D u_buffer0;
uniform sampler2D u_tex0;
uniform vec2 u_tex0Resolution;
#include "lygia/sample/clamp2edge.glsl"
#define GAUSSIANBLUR_SAMPLER_FNC(TEX, UV) sampleClamp2edge(TEX, UV)
#include "lygia/filter/gaussianBlur.glsl"
#include "lygia/draw/digits.glsl"
void main (void) {
vec3 color = vec3(0.0);
vec2 pixel = 1.0/u_resolution;
vec2 st = gl_FragCoord.xy * pixel;
float ix = floor(st.x * 5.0);
float kernel_size = max(1.0, ix * 4.0);
#ifdef BUFFER_0
color = gaussianBlur(u_tex0, st, pixel * vec2(1.0, 0.0), int(kernel_size)).rgb;
#else
color = gaussianBlur(u_buffer0, st, pixel * vec2(0.0, 1.0), int(kernel_size)).rgb;
color += digits(st - vec2(ix/5.0 + 0.01, 0.01), kernel_size, 0.0);
color -= step(.99, fract(st.x * 5.0));
#endif
gl_FragColor = vec4(color,1.0);
}