forked from AuroraMiddleware/gtk
8bcb031418
Add adds a demo showing off GskGLShaderNode in various ways. It has a transistion widget, using some examples from gl-transitions.com, with child widgets being both images, a GL area and real widgets (that let you edit the transition shaders themselves. It also has a fancy fire effect on hove on the buttons.
42 lines
970 B
GLSL
42 lines
970 B
GLSL
uniform float progress;
|
|
uniform sampler2D u_texture1;
|
|
uniform sampler2D u_texture2;
|
|
|
|
vec4 getFromColor (vec2 uv) {
|
|
return GskTexture(u_texture1, uv);
|
|
}
|
|
|
|
vec4 getToColor (vec2 uv) {
|
|
return GskTexture(u_texture2, uv);
|
|
}
|
|
|
|
// Source: https://gl-transitions.com/editor/kaleidoscope
|
|
// Author: nwoeanhinnogaehr
|
|
// License: MIT
|
|
|
|
const float speed = 1.0;
|
|
const float angle = 1.0;
|
|
const float power = 1.5;
|
|
|
|
vec4 transition(vec2 uv) {
|
|
vec2 p = uv.xy / vec2(1.0).xy;
|
|
vec2 q = p;
|
|
float t = pow(progress, power)*speed;
|
|
p = p -0.5;
|
|
for (int i = 0; i < 7; i++) {
|
|
p = vec2(sin(t)*p.x + cos(t)*p.y, sin(t)*p.y - cos(t)*p.x);
|
|
t += angle;
|
|
p = abs(mod(p, 2.0) - 1.0);
|
|
}
|
|
abs(mod(p, 1.0));
|
|
return mix(
|
|
mix(getFromColor(q), getToColor(q), progress),
|
|
mix(getFromColor(p), getToColor(p), progress), 1.0 - 2.0*abs(progress - 0.5));
|
|
}
|
|
|
|
|
|
void mainImage(out vec4 fragColor, in vec2 fragCoord, in vec2 resolution, in vec2 uv)
|
|
{
|
|
fragColor = transition(uv);
|
|
}
|