mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Prettier cheap water
This commit is contained in:
parent
40e47b4f3e
commit
af3ecbc7c4
@ -124,7 +124,7 @@ void main() {
|
|||||||
{
|
{
|
||||||
cloud_blend = 1.0 - color.a;
|
cloud_blend = 1.0 - color.a;
|
||||||
|
|
||||||
#if (FLUID_MODE >= FLUID_MODE_MEDIUM)
|
#if (FLUID_MODE >= FLUID_MODE_MEDIUM || REFLECTION_MODE >= REFLECTION_MODE_MEDIUM)
|
||||||
if (dir.z < 0.0) {
|
if (dir.z < 0.0) {
|
||||||
vec3 surf_norm = normalize(vec3(nz * 0.3 / (1.0 + dist * 0.1), 1));
|
vec3 surf_norm = normalize(vec3(nz * 0.3 / (1.0 + dist * 0.1), 1));
|
||||||
vec3 refl_dir = reflect(dir, surf_norm);
|
vec3 refl_dir = reflect(dir, surf_norm);
|
||||||
|
@ -108,7 +108,8 @@ void main() {
|
|||||||
vec3 view_dir = -cam_to_frag;
|
vec3 view_dir = -cam_to_frag;
|
||||||
// vec3 surf_color = /*srgb_to_linear*/(vec3(0.4, 0.7, 2.0));
|
// vec3 surf_color = /*srgb_to_linear*/(vec3(0.4, 0.7, 2.0));
|
||||||
|
|
||||||
vec3 water_color = (1.0 - mix(pow(MU_WATER, vec3(0.25)), pow(vec3(0.8, 0.24, 0.08), vec3(0.25)), water_col_vel(f_pos.xy))) * MU_SCATTER;
|
float water_shade = water_col_vel(f_pos.xy);
|
||||||
|
vec3 water_color = (1.0 - mix(pow(MU_WATER, vec3(0.25)), pow(vec3(0.8, 0.9, 0.08), vec3(0.125)), water_shade)) * MU_SCATTER * vec3(3, 0.5, 0.4);
|
||||||
|
|
||||||
/* vec3 sun_dir = get_sun_dir(time_of_day.x);
|
/* vec3 sun_dir = get_sun_dir(time_of_day.x);
|
||||||
vec3 moon_dir = get_moon_dir(time_of_day.x); */
|
vec3 moon_dir = get_moon_dir(time_of_day.x); */
|
||||||
@ -158,10 +159,18 @@ void main() {
|
|||||||
vec3 k_d = vec3(1.0);
|
vec3 k_d = vec3(1.0);
|
||||||
vec3 k_s = vec3(R_s);
|
vec3 k_s = vec3(R_s);
|
||||||
|
|
||||||
|
vec3 reflect_ray_dir = reflect(cam_to_frag, f_norm);
|
||||||
|
|
||||||
|
vec3 reflect_color = vec3(0.0);
|
||||||
|
#if (REFLECTION_MODE >= REFLECTION_MODE_MEDIUM)
|
||||||
|
reflect_color = get_sky_color(reflect_ray_dir, time_of_day.x, f_pos, vec3(-100000), 0.125, true, 1.0, true, sun_shade_frac);
|
||||||
|
#endif
|
||||||
|
|
||||||
vec3 emitted_light, reflected_light;
|
vec3 emitted_light, reflected_light;
|
||||||
|
|
||||||
// Prevent the sky affecting light when underground
|
// Prevent the sky affecting light when underground
|
||||||
float not_underground = clamp((f_pos.z - f_alt) / 128.0 + 1.0, 0.0, 1.0);
|
float not_underground = clamp((f_pos.z - f_alt) / 128.0 + 1.0, 0.0, 1.0);
|
||||||
|
reflect_color *= not_underground;
|
||||||
|
|
||||||
// float point_shadow = shadow_at(f_pos, f_norm);
|
// float point_shadow = shadow_at(f_pos, f_norm);
|
||||||
// vec3 cam_to_frag = normalize(f_pos - cam_pos.xyz);
|
// vec3 cam_to_frag = normalize(f_pos - cam_pos.xyz);
|
||||||
@ -215,16 +224,16 @@ void main() {
|
|||||||
// float reflected_light_point = /*length*/(diffuse_light_point.r) + f_light * point_shadow;
|
// float reflected_light_point = /*length*/(diffuse_light_point.r) + f_light * point_shadow;
|
||||||
// reflected_light += k_d * (diffuse_light_point + f_light * point_shadow * shade_frac) + specular_light_point;
|
// reflected_light += k_d * (diffuse_light_point + f_light * point_shadow * shade_frac) + specular_light_point;
|
||||||
|
|
||||||
float passthrough = max(dot(cam_norm, -cam_to_frag), 0) * 0.65;
|
float passthrough = max(dot(cam_norm, -cam_to_frag), 0);
|
||||||
|
|
||||||
float min_refl = 0.0;
|
float min_refl = 0.0;
|
||||||
float opacity = (1.0 - passthrough) * 1.0 / (1.0 + min_refl);
|
float opacity = (1.0 - passthrough) * 1.0 / (1.0 + min_refl) * 0.5;
|
||||||
if (medium.x == MEDIUM_WATER) {
|
if (medium.x == MEDIUM_WATER) {
|
||||||
// Hack to make the opacity of the surface fade when underwater to avoid artifacts
|
// Hack to make the opacity of the surface fade when underwater to avoid artifacts
|
||||||
opacity = min(sqrt(max(opacity, clamp((f_pos.z - cam_pos.z) * 0.05, 0.0, 1.0))), 1.0);
|
opacity = min(sqrt(max(opacity, clamp((f_pos.z - cam_pos.z) * 0.05, 0.0, 1.0))), 0.99);
|
||||||
}
|
}
|
||||||
|
|
||||||
vec3 surf_color = illuminate(max_light, view_dir, water_color * /* fog_color * */emitted_light, /*surf_color * */water_color * reflected_light);
|
vec3 surf_color = illuminate(max_light, view_dir, water_color * /* fog_color * */emitted_light, /*surf_color * */reflect_color * water_shade + water_color * reflected_light);
|
||||||
// vec4 color = vec4(surf_color, passthrough * 1.0 / (1.0 + min_refl));// * (1.0 - /*log(1.0 + cam_attenuation)*//*cam_attenuation*/1.0 / (2.0 - log_cam)));
|
// vec4 color = vec4(surf_color, passthrough * 1.0 / (1.0 + min_refl));// * (1.0 - /*log(1.0 + cam_attenuation)*//*cam_attenuation*/1.0 / (2.0 - log_cam)));
|
||||||
vec4 color = vec4(surf_color, opacity);
|
vec4 color = vec4(surf_color, opacity);
|
||||||
|
|
||||||
|
@ -650,10 +650,10 @@ void main() {
|
|||||||
vec3 surf_color;
|
vec3 surf_color;
|
||||||
float surf_alpha = 1.0;
|
float surf_alpha = 1.0;
|
||||||
if (length(f_col_raw - vec3(0.02, 0.06, 0.22)) < 0.025 && dot(vec3(0, 0, 1), f_norm) > 0.9) {
|
if (length(f_col_raw - vec3(0.02, 0.06, 0.22)) < 0.025 && dot(vec3(0, 0, 1), f_norm) > 0.9) {
|
||||||
|
vec3 reflect_ray = cam_to_frag * vec3(1, 1, -1);
|
||||||
#if (FLUID_MODE >= FLUID_MODE_MEDIUM)
|
#if (FLUID_MODE >= FLUID_MODE_MEDIUM)
|
||||||
vec3 water_color = (1.0 - MU_WATER) * MU_SCATTER;
|
vec3 water_color = (1.0 - MU_WATER) * MU_SCATTER;
|
||||||
|
|
||||||
vec3 reflect_ray = cam_to_frag * vec3(1, 1, -1);
|
|
||||||
|
|
||||||
float passthrough = dot(faceforward(f_norm, f_norm, cam_to_frag), -cam_to_frag);
|
float passthrough = dot(faceforward(f_norm, f_norm, cam_to_frag), -cam_to_frag);
|
||||||
|
|
||||||
@ -675,6 +675,7 @@ void main() {
|
|||||||
surf_alpha = 1.0 - passthrough;
|
surf_alpha = 1.0 - passthrough;
|
||||||
#else
|
#else
|
||||||
surf_alpha = 0.9;
|
surf_alpha = 0.9;
|
||||||
|
surf_color = get_sky_color(reflect_ray, time_of_day.x, f_pos, vec3(-100000), 0.125, true, 1.0, true, sun_shade_frac);
|
||||||
#endif
|
#endif
|
||||||
} else {
|
} else {
|
||||||
surf_color = illuminate(max_light, view_dir, f_col * emitted_light, f_col * reflected_light);
|
surf_color = illuminate(max_light, view_dir, f_col * emitted_light, f_col * reflected_light);
|
||||||
|
Loading…
Reference in New Issue
Block a user