mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Fixed internal water reflections and improved underwarper
This commit is contained in:
parent
b127cff26c
commit
fc564f5313
@ -152,6 +152,12 @@ void main() {
|
|||||||
vec3 surf_norm = vec3(mat.xyz) / 127.0 - 1.0;
|
vec3 surf_norm = vec3(mat.xyz) / 127.0 - 1.0;
|
||||||
vec3 refl_dir = reflect(dir, surf_norm);
|
vec3 refl_dir = reflect(dir, surf_norm);
|
||||||
|
|
||||||
|
// Don't reflect back into the surface by snapping the reflection to the *actual* (i.e: not normal-mapped) surface plane
|
||||||
|
if (dot(refl_dir, round(surf_norm)) <= 0.0) {
|
||||||
|
// TODO: This assumes that the surface is axis-aligned!
|
||||||
|
refl_dir = normalize(refl_dir.xyz * (1.0 - abs(round(surf_norm))));
|
||||||
|
}
|
||||||
|
|
||||||
vec4 clip = (all_mat * vec4(cam_pos.xyz + refl_dir, 1.0));
|
vec4 clip = (all_mat * vec4(cam_pos.xyz + refl_dir, 1.0));
|
||||||
vec2 new_uv = (clip.xy / max(clip.w, 0)) * 0.5 * vec2(1, -1) + 0.5;
|
vec2 new_uv = (clip.xy / max(clip.w, 0)) * 0.5 * vec2(1, -1) + 0.5;
|
||||||
|
|
||||||
|
@ -211,7 +211,7 @@ void main() {
|
|||||||
vec2 sample_uv = uv;
|
vec2 sample_uv = uv;
|
||||||
#ifdef EXPERIMENTAL_UNDERWARPER
|
#ifdef EXPERIMENTAL_UNDERWARPER
|
||||||
if (medium.x == MEDIUM_WATER) {
|
if (medium.x == MEDIUM_WATER) {
|
||||||
sample_uv += sin(uv.yx * 40 + tick.xx * 1.0) * 0.003;
|
sample_uv += sin(uv.yx * 60 + tick.xx * 3.0) * 0.003;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user