2022-06-06 22:40:38 +02:00
|
|
|
uniform float far;
|
|
|
|
|
|
|
|
#if @skyBlending
|
2022-07-09 22:21:48 +02:00
|
|
|
#include "openmw_fragment.h.glsl"
|
|
|
|
|
2022-06-06 22:40:38 +02:00
|
|
|
uniform float skyBlendingStart;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
vec4 applyFogAtDist(vec4 color, float euclideanDist, float linearDist)
|
|
|
|
{
|
|
|
|
#if @radialFog
|
|
|
|
float dist = euclideanDist;
|
|
|
|
#else
|
|
|
|
float dist = abs(linearDist);
|
|
|
|
#endif
|
|
|
|
#if @exponentialFog
|
|
|
|
float fogValue = 1.0 - exp(-2.0 * max(0.0, dist - gl_Fog.start/2.0) / (gl_Fog.end - gl_Fog.start/2.0));
|
|
|
|
#else
|
|
|
|
float fogValue = clamp((dist - gl_Fog.start) * gl_Fog.scale, 0.0, 1.0);
|
|
|
|
#endif
|
2022-06-21 22:28:17 +02:00
|
|
|
#ifdef ADDITIVE_BLENDING
|
2022-07-04 17:31:03 +00:00
|
|
|
color.xyz *= 1.0 - fogValue;
|
2022-06-21 22:28:17 +02:00
|
|
|
#else
|
2022-06-06 22:40:38 +02:00
|
|
|
color.xyz = mix(color.xyz, gl_Fog.color.xyz, fogValue);
|
2022-06-21 22:28:17 +02:00
|
|
|
#endif
|
2022-06-06 22:40:38 +02:00
|
|
|
|
2022-07-09 22:21:48 +02:00
|
|
|
#if @skyBlending
|
2022-06-06 22:40:38 +02:00
|
|
|
float fadeValue = clamp((far - dist) / (far - skyBlendingStart), 0.0, 1.0);
|
2022-06-21 22:28:17 +02:00
|
|
|
fadeValue *= fadeValue;
|
|
|
|
#ifdef ADDITIVE_BLENDING
|
|
|
|
color.xyz *= fadeValue;
|
|
|
|
#else
|
2022-07-09 22:21:48 +02:00
|
|
|
color.xyz = mix(mw_sampleSkyColor(gl_FragCoord.xy / screenRes), color.xyz, fadeValue);
|
2022-06-21 22:28:17 +02:00
|
|
|
#endif
|
2022-06-06 22:40:38 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
return color;
|
|
|
|
}
|
|
|
|
|
|
|
|
vec4 applyFogAtPos(vec4 color, vec3 pos)
|
|
|
|
{
|
|
|
|
return applyFogAtDist(color, length(pos), pos.z);
|
|
|
|
}
|