2023-04-07 08:17:37 +02:00
|
|
|
#version 330 core
|
|
|
|
|
|
|
|
uniform sampler2D depth_tex;
|
|
|
|
|
|
|
|
uniform vec2 fg_NearFar;
|
|
|
|
uniform mat4 fg_ViewMatrixInverse;
|
|
|
|
uniform mat4 fg_ProjectionMatrixInverse;
|
|
|
|
|
2024-01-31 00:24:01 +01:00
|
|
|
uniform vec2 fg_FOVScale;
|
|
|
|
|
|
|
|
// logarithmic_depth.glsl
|
|
|
|
float logdepth_decode(float z);
|
|
|
|
|
2023-04-07 08:17:37 +02:00
|
|
|
/*
|
|
|
|
* Reconstruct the view space position from the depth buffer. Mostly used by
|
|
|
|
* fullscreen post-processing shaders.
|
|
|
|
*
|
|
|
|
* Given a 2D screen UV in the range [0,1] and a depth value from the depth
|
|
|
|
* buffer, also in the [0,1] range, return the view space position.
|
|
|
|
*/
|
|
|
|
vec3 get_view_space_from_depth(vec2 uv, float depth)
|
|
|
|
{
|
2024-01-31 00:24:01 +01:00
|
|
|
float vs_depth = logdepth_decode(depth);
|
|
|
|
vec2 half_ndc_pos = vec2(0.5) - uv;
|
|
|
|
vec3 vs_pos = vec3(half_ndc_pos * fg_FOVScale * (-vs_depth), -vs_depth);
|
|
|
|
return vs_pos;
|
2023-04-07 08:17:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
vec3 get_view_space_from_depth(vec2 uv)
|
|
|
|
{
|
|
|
|
return get_view_space_from_depth(uv, texture(depth_tex, uv).r);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec3 get_world_space_from_depth(vec2 uv, float depth)
|
|
|
|
{
|
|
|
|
vec4 vs_p = vec4(get_view_space_from_depth(uv, depth), 1.0);
|
|
|
|
return (fg_ViewMatrixInverse * vs_p).xyz;
|
|
|
|
}
|
|
|
|
|
|
|
|
vec3 get_world_space_from_depth(vec2 uv)
|
|
|
|
{
|
|
|
|
return get_world_space_from_depth(uv, texture(depth_tex, uv).r);
|
|
|
|
}
|