This commit is contained in:
2025-04-29 13:39:02 -05:00
commit 9cbb583982
2257 changed files with 77258 additions and 0 deletions

View File

@@ -0,0 +1,16 @@
varying vec4 v_TexCoord;
varying vec2 v_ReflectedCoord;
uniform sampler2D g_Texture0; // {"material":"Framebuffer","hidden":true}
uniform sampler2D g_Texture1; // {"material":"Mask","mode":"opacitymask","default":"util/black"}
uniform float g_Additive; // {"material":"Additive","default":1,"range":[0,1]}
void main() {
vec4 albedo = texSample2D(g_Texture0, v_TexCoord.xy);
vec4 reflected = texSample2D(g_Texture0, v_ReflectedCoord);
float mask = texSample2D(g_Texture1, v_TexCoord.zw).r;
gl_FragColor = mix(mix(albedo, reflected, mask), albedo + reflected * mask, g_Additive);
}

View File

@@ -0,0 +1,29 @@
#include "common.h"
uniform mat4 g_ModelViewProjectionMatrix;
uniform vec4 g_Texture1Resolution;
uniform float g_Direction; // {"material":"Direction","default":0,"range":[0,6.28]}
uniform float g_ReflectionOffset; // {"material":"Offset","default":0.0,"range":[-1,1]}
attribute vec3 a_Position;
attribute vec2 a_TexCoord;
varying vec4 v_TexCoord;
varying vec2 v_ReflectedCoord;
void main() {
gl_Position = mul(vec4(a_Position, 1.0), g_ModelViewProjectionMatrix);
v_TexCoord.xy = a_TexCoord;
v_TexCoord.zw = vec2(v_TexCoord.x * g_Texture1Resolution.z / g_Texture1Resolution.x,
v_TexCoord.y * g_Texture1Resolution.w / g_Texture1Resolution.y);
vec2 center = vec2(0.5, 0.5);
vec2 delta = a_TexCoord - center;
delta.y += g_ReflectionOffset;
delta.y = -delta.y;
delta = rotateVec2(delta, g_Direction);
v_ReflectedCoord = center + delta;
}

View File

@@ -0,0 +1,26 @@
varying vec4 v_TexCoord;
varying vec2 v_Scroll;
uniform sampler2D g_Texture0; // {"material":"Framebuffer","hidden":true}
uniform sampler2D g_Texture1; // {"material":"Water normal"}
uniform sampler2D g_Texture2; // {"material":"Mask","mode":"opacitymask","default":"util/white"}
uniform float g_Strength; // {"material":"Ripple strength","default":0.1,"range":[0,1]}
varying vec4 v_TexCoordRipple;
void main() {
vec2 texCoord = v_TexCoord.xy;
float mask = texSample2D(g_Texture2, v_TexCoord.zw).r;
vec3 n1 = texSample2D(g_Texture1, v_TexCoordRipple.xy).xyz * 2 - 1;
vec3 n2 = texSample2D(g_Texture1, v_TexCoordRipple.zw).xyz * 2 - 1;
vec3 normal = normalize(vec3(n1.xy + n2.xy, n1.z));
texCoord.xy += normal.xy * g_Strength * g_Strength * mask;
gl_FragColor = texSample2D(g_Texture0, texCoord);
}

View File

@@ -0,0 +1,41 @@
#include "common.h"
uniform mat4 g_ModelViewProjectionMatrix;
uniform float g_Time;
uniform vec4 g_Texture0Resolution;
uniform vec4 g_Texture2Resolution;
uniform float g_AnimationSpeed; // {"material":"Animation speed","default":0.15,"range":[0,0.5]}
uniform float g_Scale; // {"material":"Ripple scale","default":1,"range":[0,10]}
uniform float g_ScrollSpeed; // {"material":"Scroll speed","default":0,"range":[0,0.5]}
uniform float g_Direction; // {"material":"Scroll direction","default":0,"range":[0,6.28]}
attribute vec3 a_Position;
attribute vec2 a_TexCoord;
varying vec4 v_TexCoord;
varying vec4 v_TexCoordRipple;
void main() {
gl_Position = mul(vec4(a_Position, 1.0), g_ModelViewProjectionMatrix);
v_TexCoord.xy = a_TexCoord;
float piFrac = 0.78539816339744830961566084581988 * 0.5;
float pi = 3.141;
vec2 coordsRotated = v_TexCoord.xy;
vec2 coordsRotated2 = v_TexCoord.xy * 1.333;
vec2 scroll = rotateVec2(vec2(0, -1), g_Direction) * g_ScrollSpeed * g_ScrollSpeed * g_Time;
v_TexCoordRipple.xy = coordsRotated + g_Time * g_AnimationSpeed * g_AnimationSpeed + scroll;
v_TexCoordRipple.zw = coordsRotated2 - g_Time * g_AnimationSpeed * g_AnimationSpeed + scroll;
v_TexCoordRipple *= g_Scale;
float rippleTextureAdjustment = (g_Texture0Resolution.x / g_Texture0Resolution.y);
v_TexCoordRipple.xz *= rippleTextureAdjustment;
v_TexCoord.zw = vec2(v_TexCoord.x * g_Texture2Resolution.z / g_Texture2Resolution.x,
v_TexCoord.y * g_Texture2Resolution.w / g_Texture2Resolution.y);
}