2024-06-19 21:44:21 -04:00
|
|
|
uniform float far;
|
|
|
|
uniform int dhRenderDistance;
|
|
|
|
|
2023-01-12 15:00:14 -05:00
|
|
|
const float k = 1.8;
|
2024-06-19 21:44:21 -04:00
|
|
|
const float d0 = 0.04 + max(64.0 - shadowDistance, 0.0)/64.0 * 0.26;
|
2023-01-12 15:00:14 -05:00
|
|
|
const float d1 = 0.61;
|
|
|
|
float a = exp(d0);
|
2024-06-25 20:34:45 -04:00
|
|
|
float b = (exp(d1)-a)*150./128.0;
|
|
|
|
|
2024-06-19 21:44:21 -04:00
|
|
|
// thank you Espen
|
2024-06-25 20:34:45 -04:00
|
|
|
// #ifdef DISTANT_HORIZONS_SHADOWMAP
|
|
|
|
// float b = (exp(d1)-a)*min(dhRenderDistance, shadowDistance)/shadowDistance;
|
|
|
|
// #else
|
|
|
|
// float b = (exp(d1)-a)*min(far+16.0*3.5, shadowDistance)/shadowDistance;
|
|
|
|
// #endif
|
2023-01-12 15:00:14 -05:00
|
|
|
|
|
|
|
vec4 BiasShadowProjection(in vec4 projectedShadowSpacePosition) {
|
|
|
|
|
|
|
|
float distortFactor = log(length(projectedShadowSpacePosition.xy)*b+a)*k;
|
|
|
|
projectedShadowSpacePosition.xy /= distortFactor;
|
|
|
|
return projectedShadowSpacePosition;
|
|
|
|
}
|
|
|
|
|
|
|
|
float calcDistort(vec2 worldpos){
|
|
|
|
return 1.0/(log(length(worldpos)*b+a)*k);
|
2024-06-19 21:44:21 -04:00
|
|
|
}
|