2019-11-21 20:57:46 +00:00
|
|
|
#version 330 core
|
|
|
|
|
|
|
|
#include <globals.glsl>
|
|
|
|
#include <sky.glsl>
|
|
|
|
#include <lod.glsl>
|
|
|
|
|
|
|
|
in vec3 f_pos;
|
2020-02-23 16:53:17 +00:00
|
|
|
in vec3 f_norm;
|
2019-11-21 20:57:46 +00:00
|
|
|
|
|
|
|
out vec4 tgt_color;
|
|
|
|
|
|
|
|
#include <sky.glsl>
|
|
|
|
|
|
|
|
void main() {
|
|
|
|
vec3 f_norm = lod_norm(f_pos.xy);
|
2019-11-22 10:09:00 +00:00
|
|
|
|
2019-11-21 20:57:46 +00:00
|
|
|
vec3 f_col = lod_col(f_pos.xy);
|
|
|
|
|
2020-04-04 00:32:39 +00:00
|
|
|
vec3 emitted_light, reflected_light;
|
2020-04-09 00:38:40 +00:00
|
|
|
vec4 vert_pos4 = view_mat * vec4(f_pos, 1.0);
|
|
|
|
vec3 view_dir = normalize(-vec3(vert_pos4) / vert_pos4.w);
|
2020-04-04 00:32:39 +00:00
|
|
|
vec3 cam_to_frag = normalize(f_pos - cam_pos.xyz);
|
2020-04-09 00:38:40 +00:00
|
|
|
|
|
|
|
// Note: because voxels, we reduce the normal for reflections to just its z component, dpendng on distance to camera.
|
|
|
|
// Idea: the closer we are to facing top-down, the more the norm should tend towards up-z.
|
|
|
|
vec3 l_norm = vec3(0.0, 0.0, 1.0);
|
|
|
|
// vec3 l_norm = normalize(vec3(f_norm.x / max(abs(f_norm.x), 0.001), f_norm.y / max(abs(f_norm.y), 0.001), f_norm.z / max(abs(f_norm.z), 0.001)));
|
|
|
|
// vec3 l_factor = 1.0 / (1.0 + max(abs(/*f_pos - cam_pos.xyz*//*-vec3(vert_pos4) / vert_pos4.w*/vec3(f_pos.xy, 0.0) - vec3(/*cam_pos*/focus_pos.xy, cam_to_frag)) - vec3(view_distance.x, view_distance.x, 0.0), 0.0) / vec3(32.0 * 2.0, 32.0 * 2.0, 1.0));
|
|
|
|
// l_factor.z =
|
|
|
|
// vec4 focus_pos4 = view_mat * vec4(focus_pos.xyz, 1.0);
|
|
|
|
// vec3 focus_dir = normalize(-vec3(focus_pos4) / focus_pos4.w);
|
|
|
|
float l_factor = 1.0 - pow(clamp(0.5 + 0.5 * dot(/*-view_dir*/-cam_to_frag, l_norm), 0.0, 1.0), 2.0);//1.0 / (1.0 + 0.5 * pow(max(distance(/*focus_pos.xy*/vec3(focus_pos.xy, /*vert_pos4.z / vert_pos4.w*/f_pos.z), vec3(f_pos.xy, f_pos.z))/* - view_distance.x*/ - 32.0, 0.0) / (32.0 * 1.0), /*0.5*/1.0));
|
|
|
|
l_factor = 1.0;
|
|
|
|
l_norm = normalize(mix(l_norm, f_norm, l_factor));
|
|
|
|
/* l_norm = normalize(vec3(
|
|
|
|
mix(l_norm.x, f_norm.x, clamp(pow(f_norm.x * 0.5, 64), 0, 1)),
|
|
|
|
mix(-1.0, 1.0, clamp(pow(f_norm.y * 0.5, 64), 0, 1)),
|
|
|
|
mix(-1.0, 1.0, clamp(pow(f_norm.z * 0.5, 64), 0, 1))
|
|
|
|
)); */
|
|
|
|
// f_norm = mix(l_norm, f_norm, min(1.0 / max(cam_to_frag, 0.001), 1.0));
|
|
|
|
/* vec3 l_norm = normalize(vec3(
|
|
|
|
mix(-1.0, 1.0, clamp(pow(f_norm.x * 0.5, 64), 0, 1)),
|
|
|
|
mix(-1.0, 1.0, clamp(pow(f_norm.y * 0.5, 64), 0, 1)),
|
|
|
|
mix(-1.0, 1.0, clamp(pow(f_norm.z * 0.5, 64), 0, 1))
|
|
|
|
)); */
|
|
|
|
|
|
|
|
// Use f_norm here for better shadows.
|
|
|
|
vec3 light_frac = light_reflection_factor(l_norm, view_dir, vec3(0, 0, -1.0), vec3(1.0), vec3(1.0), 4.0);
|
|
|
|
|
|
|
|
vec3 sun_dir = get_sun_dir(time_of_day.x);
|
|
|
|
vec3 moon_dir = get_moon_dir(time_of_day.x);
|
|
|
|
// float sun_light = get_sun_brightness(sun_dir);
|
|
|
|
// float moon_light = get_moon_brightness(moon_dir);
|
|
|
|
float sun_shade_frac = horizon_at(f_pos, sun_dir);
|
|
|
|
float moon_shade_frac = horizon_at(f_pos, moon_dir);
|
|
|
|
// Globbal illumination "estimate" used to light the faces of voxels which are parallel to the sun or moon (which is a very common occurrence).
|
|
|
|
// Will be attenuated by k_d, which is assumed to carry any additional ambient occlusion information (e.g. about shadowing).
|
|
|
|
// float ambient_sides = clamp(mix(0.5, 0.0, abs(dot(-f_norm, sun_dir)) * 10000.0), 0.0, 0.5);
|
|
|
|
// NOTE: current assumption is that moon and sun shouldn't be out at the sae time.
|
|
|
|
// This assumption is (or can at least easily be) wrong, but if we pretend it's true we avoids having to explicitly pass in a separate shadow
|
|
|
|
// for the sun and moon (since they have different brightnesses / colors so the shadows shouldn't attenuate equally).
|
|
|
|
float shade_frac = sun_shade_frac + moon_shade_frac;
|
|
|
|
// float brightness_denominator = (ambient_sides + vec3(SUN_AMBIANCE * sun_light + moon_light);
|
|
|
|
|
2020-04-04 00:32:39 +00:00
|
|
|
// vec3 light, diffuse_light, ambient_light;
|
2020-04-09 00:38:40 +00:00
|
|
|
// get_sun_diffuse(f_norm, time_of_day.x, cam_to_frag, (0.25 * shade_frac + 0.25 * light_frac) * f_col, 0.5 * shade_frac * f_col, 0.5 * shade_frac * /*vec3(1.0)*/f_col, 2.0, emitted_light, reflected_light);
|
|
|
|
get_sun_diffuse(l_norm, time_of_day.x, view_dir, 1.0 * (0.5 * light_frac + vec3(0.5 * shade_frac)), vec3(shade_frac * 0.5), /*0.5 * shade_frac * *//*vec3(1.0)*//*f_col*/vec3(shade_frac * 0.5), 4.0, emitted_light, reflected_light);
|
|
|
|
|
|
|
|
// emitted_light += 0.5 * vec3(SUN_AMBIANCE * sun_shade_frac * sun_light + moon_shade_frac * moon_light) * f_col * (ambient_sides + 1.0);
|
|
|
|
|
|
|
|
// Ambient lighting attempt: vertical light.
|
|
|
|
// reflected_light += /*0.0125*/0.15 * 0.25 * _col * light_reflection_factor(f_norm, cam_to_frag, vec3(0, 0, -1.0), 0.5 * f_col, 0.5 * f_col, 2.0);
|
|
|
|
// emitted_light += /*0.0125*/0.25 * f_col * ;
|
2020-04-04 00:32:39 +00:00
|
|
|
// vec3 light, diffuse_light, ambient_light;
|
|
|
|
// get_sun_diffuse(f_norm, time_of_day.x, light, diffuse_light, ambient_light, 1.0);
|
|
|
|
// vec3 surf_color = illuminate(f_col, light, diffuse_light, ambient_light);
|
2020-04-09 00:38:40 +00:00
|
|
|
vec3 surf_color = /*illuminate(emitted_light, reflected_light)*/illuminate(f_col * emitted_light, f_col * reflected_light);
|
2019-11-21 20:57:46 +00:00
|
|
|
|
|
|
|
float fog_level = fog(f_pos.xyz, focus_pos.xyz, medium.x);
|
2020-02-24 17:49:53 +00:00
|
|
|
|
2019-11-21 20:57:46 +00:00
|
|
|
vec4 clouds;
|
2020-04-04 00:32:39 +00:00
|
|
|
vec3 fog_color = get_sky_color(cam_to_frag, time_of_day.x, cam_pos.xyz, f_pos, 1.0, true, clouds);
|
2019-11-22 12:40:48 +00:00
|
|
|
vec3 color = mix(mix(surf_color, fog_color, fog_level), clouds.rgb, clouds.a);
|
2020-04-09 00:38:40 +00:00
|
|
|
// vec3 color = surf_color;
|
2019-11-21 20:57:46 +00:00
|
|
|
|
2020-04-09 00:38:40 +00:00
|
|
|
// float mist_factor = max(1 - (f_pos.z + (texture(t_noise, f_pos.xy * 0.0005 + time_of_day.x * 0.0003).x - 0.5) * 128.0) / 400.0, 0.0);
|
2020-02-24 17:49:53 +00:00
|
|
|
//float mist_factor = f_norm.z * 2.0;
|
2020-04-09 00:38:40 +00:00
|
|
|
// color = mix(color, vec3(1.0) * /*diffuse_light*/reflected_light, clamp(mist_factor * 0.00005 * distance(f_pos.xy, focus_pos.xy), 0, 0.3));
|
|
|
|
// color = surf_color;
|
2020-02-24 17:49:53 +00:00
|
|
|
|
2019-11-21 20:57:46 +00:00
|
|
|
tgt_color = vec4(color, 1.0);
|
|
|
|
}
|