stk-code_catmod/data/shaders/fog.frag

24 lines
549 B
GLSL
Raw Normal View History

uniform sampler2D tex;
uniform float density;
uniform vec3 col;
out vec4 FragColor;
vec4 getPosFromUVDepth(vec3 uvDepth, mat4 InverseProjectionMatrix);
void main()
{
2014-11-11 16:43:25 -05:00
vec2 uv = 2. * gl_FragCoord.xy / screen;
2014-11-10 16:08:12 -05:00
float z = texture(tex, uv).x;
vec4 xpos = getPosFromUVDepth(vec3(uv, z), InverseProjectionMatrix);
2014-11-10 16:08:12 -05:00
float dist = length(xpos.xyz);
float factor = (1. - exp(- density * dist));
vec3 fog = col * factor;
// fog is scattering component, factor is the beer lambert absorption
FragColor = vec4(fog, factor);
}