2023-02-25 19:03:39 +00:00
|
|
|
#ifndef LIB_VIEW_DEPTH
|
|
|
|
#define LIB_VIEW_DEPTH
|
|
|
|
|
|
|
|
float linearizeDepth(float depth, float near, float far)
|
|
|
|
{
|
|
|
|
#if @reverseZ
|
2023-04-21 05:02:12 +00:00
|
|
|
depth = 1.0 - depth;
|
2023-02-25 19:03:39 +00:00
|
|
|
#endif
|
2023-04-21 05:02:12 +00:00
|
|
|
float z_n = 2.0 * depth - 1.0;
|
|
|
|
depth = 2.0 * near * far / (far + near - z_n * (far - near));
|
|
|
|
return depth;
|
2023-02-25 19:03:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
float getLinearDepth(in float z, in float viewZ)
|
|
|
|
{
|
|
|
|
#if @reverseZ
|
|
|
|
// FIXME: Fixme, figure out how to calculate correct linear depth for reverse z
|
|
|
|
return -viewZ;
|
|
|
|
#else
|
|
|
|
return z;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|