2022-01-13 05:24:03 +01:00
|
|
|
varying vec2 v_vTexcoord;
|
|
|
|
varying vec4 v_vColour;
|
|
|
|
|
2024-09-25 04:04:06 +02:00
|
|
|
uniform vec2 dimension;
|
2022-01-13 05:24:03 +01:00
|
|
|
uniform float seed;
|
2024-09-23 13:27:31 +02:00
|
|
|
uniform float colrSeed;
|
2023-12-23 09:39:55 +01:00
|
|
|
uniform vec2 position;
|
2024-01-29 14:33:55 +01:00
|
|
|
uniform int mode;
|
2023-12-23 09:39:55 +01:00
|
|
|
|
|
|
|
uniform vec2 noiseX;
|
|
|
|
uniform int noiseXUseSurf;
|
|
|
|
uniform sampler2D noiseXSurf;
|
|
|
|
|
|
|
|
uniform vec2 noiseY;
|
|
|
|
uniform int noiseYUseSurf;
|
|
|
|
uniform sampler2D noiseYSurf;
|
|
|
|
|
|
|
|
uniform vec2 angle;
|
|
|
|
uniform int angleUseSurf;
|
|
|
|
uniform sampler2D angleSurf;
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2024-09-23 13:27:31 +02:00
|
|
|
float random1D (in vec2 st, float _seed) { return fract(sin(dot(st.xy, vec2(12.9898, 78.233)) * mod(_seed + 453.456, 100.) * 12.588) * 43758.5453123); }
|
2023-01-09 03:14:20 +01:00
|
|
|
|
2024-09-23 13:27:31 +02:00
|
|
|
float random (in vec2 st, float _seed) { return mix(random1D(st, floor(_seed)), random1D(st, floor(_seed) + 1.), fract(_seed)); }
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
void main() {
|
2023-12-23 09:39:55 +01:00
|
|
|
#region params
|
|
|
|
float nsx = noiseX.x;
|
|
|
|
if(noiseXUseSurf == 1) {
|
|
|
|
vec4 _vMap = texture2D( noiseXSurf, v_vTexcoord );
|
|
|
|
nsx = mix(noiseX.x, noiseX.y, (_vMap.r + _vMap.g + _vMap.b) / 3.);
|
|
|
|
}
|
|
|
|
|
|
|
|
float nsy = noiseY.y;
|
|
|
|
if(noiseYUseSurf == 1) {
|
|
|
|
vec4 _vMap = texture2D( noiseYSurf, v_vTexcoord );
|
|
|
|
nsy = mix(noiseY.x, noiseY.y, (_vMap.r + _vMap.g + _vMap.b) / 3.);
|
|
|
|
}
|
|
|
|
|
|
|
|
float ang = angle.x;
|
|
|
|
if(angleUseSurf == 1) {
|
|
|
|
vec4 _vMap = texture2D( angleSurf, v_vTexcoord );
|
|
|
|
ang = mix(angle.x, angle.y, (_vMap.r + _vMap.g + _vMap.b) / 3.);
|
|
|
|
}
|
|
|
|
ang = radians(ang);
|
|
|
|
#endregion
|
|
|
|
|
2024-09-25 04:04:06 +02:00
|
|
|
vec2 ntx = v_vTexcoord * vec2(1., dimension.y / dimension.x);
|
|
|
|
vec2 pos = (ntx - position) * mat2(cos(ang), - sin(ang), sin(ang), cos(ang));
|
2022-12-13 09:20:36 +01:00
|
|
|
|
2024-01-29 14:33:55 +01:00
|
|
|
float yy = floor(pos.y * nsy);
|
2024-09-23 13:27:31 +02:00
|
|
|
float xx = (pos.x + random(vec2(1., yy), seed)) * nsx;
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2024-01-29 14:33:55 +01:00
|
|
|
float x0 = floor(xx);
|
|
|
|
float x1 = floor(xx) + 1.;
|
|
|
|
float prog = xx - x0;
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2024-01-29 14:33:55 +01:00
|
|
|
if(mode == 0) {
|
2024-09-23 13:27:31 +02:00
|
|
|
float noise0 = random(vec2(x0, yy), colrSeed); // point before
|
|
|
|
float noise1 = random(vec2(x1, yy), colrSeed); // point after
|
2024-01-29 14:33:55 +01:00
|
|
|
|
|
|
|
gl_FragColor = vec4(vec3(mix(noise0, noise1, prog)), 1.);
|
2024-09-23 13:27:31 +02:00
|
|
|
|
2024-01-29 14:33:55 +01:00
|
|
|
} else if(mode == 1) {
|
|
|
|
gl_FragColor = vec4(vec3(prog), 1.);
|
|
|
|
}
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|