#define step 3.0 uniform sampler2D u_texture; uniform float u_time; uniform float u_progress; uniform vec4 u_color; uniform vec2 u_uv; uniform vec2 u_uv2; uniform vec2 u_texsize; varying vec4 v_color; varying vec2 v_texCoords; bool id(vec4 v){ return v.a > 0.1; } bool id(vec2 coords, vec4 base){ vec4 target = texture2D(u_texture, coords); return target.a < 0.1 || (coords.x < u_uv.x || coords.y < u_uv.y || coords.x > u_uv2.x || coords.y > u_uv2.y); } bool cont(vec2 T, vec2 v){ vec4 base = texture2D(u_texture, T); return base.a > 0.1 && (id(T + vec2(0, step) * v, base) || id(T + vec2(0, -step) * v, base) || id(T + vec2(step, 0) * v, base) || id(T + vec2(-step, 0) * v, base) || id(T + vec2(step, step) * v, base) || id(T + vec2(-step, -step) * v, base) || id(T + vec2(step, -step) * v, base) || id(T + vec2(-step, step) * v, base)); } void main() { vec2 coords = (v_texCoords.xy - u_uv) / (u_uv2 - u_uv); vec2 t = v_texCoords.xy; vec2 v = vec2(1.0/u_texsize.x, 1.0/u_texsize.y); vec4 c = texture2D(u_texture, v_texCoords.xy); float alpha = c.a; c.a *= u_progress; if(c.a > 0.01){ float f = abs(sin(coords.x*2.0 + u_time)); if(f > 0.9) f = 1.0; else f = 0.0; c = mix(c, u_color, f * u_color.a); } c.a *= alpha; gl_FragColor = c * v_color; }