summaryrefslogtreecommitdiffstats
path: root/water
diff options
context:
space:
mode:
authordusoleil <howcansocksbereal@gmail.com>2022-09-15 07:38:57 -0400
committerdusoleil <howcansocksbereal@gmail.com>2022-09-15 07:38:57 -0400
commitfb12038102da5f225779e9735a8ab47b880913e5 (patch)
tree07296f8e391df2e42dc7af99396c21730bfb6aa6 /water
parent764f4d2787418f760e20546ab7abfa07718988e9 (diff)
downloadgodot_wildjam_49-fb12038102da5f225779e9735a8ab47b880913e5.tar.gz
godot_wildjam_49-fb12038102da5f225779e9735a8ab47b880913e5.zip
Fix water refraction and remove ghosting
Diffstat (limited to 'water')
-rw-r--r--water/Wave.gdshader32
1 files changed, 22 insertions, 10 deletions
diff --git a/water/Wave.gdshader b/water/Wave.gdshader
index 9e4aff3..ee06fe0 100644
--- a/water/Wave.gdshader
+++ b/water/Wave.gdshader
@@ -16,6 +16,7 @@ uniform sampler2D noise;
uniform float foam_amount = 0.6;
uniform float murkiness = 4.0;
+uniform float refraction_amount = 0.01;
varying float vertex_y;
@@ -66,6 +67,17 @@ void vertex()
NORMAL = normalize(cross(BINORMAL,TANGENT));
}
+float get_depth(vec2 coords, sampler2D tex, mat4 proj)
+{
+ float depth = texture(tex, coords).r;
+ vec3 depth_coords_clip = vec3(coords, depth);
+ depth_coords_clip = depth_coords_clip * 2.0 - 1.0;
+ vec4 depth_coords_view = proj * vec4(depth_coords_clip,1.0);
+ depth_coords_view.xyz /= depth_coords_view.w;
+ depth = -depth_coords_view.z;
+ return depth;
+}
+
void fragment()
{
ALPHA = 1.0;
@@ -75,27 +87,27 @@ void fragment()
NORMALMAP = texture(noise, UV + (TIME * vec2(-1.0,0.0) * 0.05)).xyz;
NORMALMAP_DEPTH = 0.3;
- float depth = texture(DEPTH_TEXTURE, SCREEN_UV).r;
- vec3 depth_coords_clip = vec3(SCREEN_UV, depth);
- depth_coords_clip = depth_coords_clip * 2.0 - 1.0;
- vec4 depth_coords_view = INV_PROJECTION_MATRIX * vec4(depth_coords_clip,1.0);
- depth_coords_view.xyz /= depth_coords_view.w;
- depth = -depth_coords_view.z;
+ float depth = get_depth(SCREEN_UV, DEPTH_TEXTURE, INV_PROJECTION_MATRIX);
float water_depth = -VERTEX.z;
float submersion = depth - water_depth;
-
vec4 water_color = mix(deep_water_colour, water_colour, clamp(vertex_y,0.0,1.0));
float foam = clamp((foam_amount - submersion) / foam_amount, 0.0, 1.0);
ALBEDO = mix(water_color, vec4(1.0), foam).rgb;
vec3 oriented_normalmap = vec3(TANGENT*NORMALMAP.x + NORMAL*NORMALMAP.y + BINORMAL*NORMALMAP.z);
vec3 normal = normalize(mix(NORMAL,oriented_normalmap,NORMALMAP_DEPTH));
- vec2 refraction_uv = SCREEN_UV + (normal.xz * 0.005);
+ vec2 refraction_uv = SCREEN_UV + (normal.xz * (refraction_amount / exp(water_depth/20.0)));
float murky = murkiness * ROUGHNESS;
+ depth = get_depth(refraction_uv, DEPTH_TEXTURE, INV_PROJECTION_MATRIX);
+ submersion = depth - water_depth;
murky *= submersion;
+ float depth_visibility = 0.0;
+ if(submersion >= 0.0)
+ {
+ depth_visibility = exp(-murky);
+ depth_visibility = clamp(depth_visibility,0.0,1.0);
+ }
float depth_scatter = exp(murky);
- float depth_visibility = exp(-murky);
- depth_visibility = clamp(depth_visibility,0.0,1.0);
vec4 bg_color = textureLod(SCREEN_TEXTURE, refraction_uv, depth_scatter);
EMISSION = mix(water_color, bg_color, depth_visibility).rgb * (1.0 - water_color.a);
}