mirror of
https://github.com/ZDoom/qzdoom.git
synced 2024-11-10 14:51:51 +00:00
Fix stripes in the reconstructed normals due to down scaling
This commit is contained in:
parent
11725c435e
commit
24ab13f1ce
2 changed files with 11 additions and 8 deletions
|
@ -182,7 +182,7 @@ void FGLRenderer::AmbientOccludeScene()
|
||||||
mLinearDepthShader->LinearizeDepthB[multisample].Set(MAX(1.0f / GetZNear(), 1.e-8f));
|
mLinearDepthShader->LinearizeDepthB[multisample].Set(MAX(1.0f / GetZNear(), 1.e-8f));
|
||||||
mLinearDepthShader->InverseDepthRangeA[multisample].Set(1.0f);
|
mLinearDepthShader->InverseDepthRangeA[multisample].Set(1.0f);
|
||||||
mLinearDepthShader->InverseDepthRangeB[multisample].Set(0.0f);
|
mLinearDepthShader->InverseDepthRangeB[multisample].Set(0.0f);
|
||||||
mLinearDepthShader->Scale[multisample].Set(mSceneViewport.width / (float)mScreenViewport.width, mSceneViewport.height / (float)mScreenViewport.height);
|
mLinearDepthShader->Scale[multisample].Set(mBuffers->AmbientWidth * 2.0f / (float)mScreenViewport.width, mBuffers->AmbientHeight * 2.0f / (float)mScreenViewport.height);
|
||||||
mLinearDepthShader->Offset[multisample].Set(mSceneViewport.left / (float)mScreenViewport.width, mSceneViewport.top / (float)mScreenViewport.height);
|
mLinearDepthShader->Offset[multisample].Set(mSceneViewport.left / (float)mScreenViewport.width, mSceneViewport.top / (float)mScreenViewport.height);
|
||||||
RenderScreenQuad();
|
RenderScreenQuad();
|
||||||
|
|
||||||
|
|
|
@ -24,18 +24,21 @@ void main()
|
||||||
|
|
||||||
#if defined(MULTISAMPLE)
|
#if defined(MULTISAMPLE)
|
||||||
ivec2 texSize = textureSize(DepthTexture);
|
ivec2 texSize = textureSize(DepthTexture);
|
||||||
ivec2 ipos = ivec2(uv * vec2(texSize));
|
#else
|
||||||
|
ivec2 texSize = textureSize(DepthTexture, 0);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Use floor here because as we downscale the sampling error has to remain uniform to prevent
|
||||||
|
// noise in the depth values.
|
||||||
|
ivec2 ipos = ivec2(max(floor(uv * vec2(texSize) - 0.75), vec2(0.0)));
|
||||||
|
|
||||||
|
#if defined(MULTISAMPLE)
|
||||||
float depth = 0.0;
|
float depth = 0.0;
|
||||||
for (int i = 0; i < SampleCount; i++)
|
for (int i = 0; i < SampleCount; i++)
|
||||||
depth += texelFetch(ColorTexture, ipos, i).a != 0.0 ? texelFetch(DepthTexture, ipos, i).x : 1.0;
|
depth += texelFetch(ColorTexture, ipos, i).a != 0.0 ? texelFetch(DepthTexture, ipos, i).x : 1.0;
|
||||||
depth /= float(SampleCount);
|
depth /= float(SampleCount);
|
||||||
#else
|
#else
|
||||||
/*ivec2 texSize = textureSize(DepthTexture, 0);
|
float depth = texelFetch(ColorTexture, ipos, 0).a != 0.0 ? texelFetch(DepthTexture, ipos, 0).x : 1.0;
|
||||||
ivec2 ipos = ivec2(uv * vec2(texSize));
|
|
||||||
if (ipos.x < 0) ipos.x += texSize.x;
|
|
||||||
if (ipos.y < 0) ipos.y += texSize.y;
|
|
||||||
float depth = texelFetch(ColorTexture, ipos, 0).a != 0.0 ? texelFetch(DepthTexture, ipos, 0).x : 1.0;*/
|
|
||||||
float depth = texture(ColorTexture, uv).a != 0.0 ? texture(DepthTexture, uv).x : 1.0;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
float normalizedDepth = clamp(InverseDepthRangeA * depth + InverseDepthRangeB, 0.0, 1.0);
|
float normalizedDepth = clamp(InverseDepthRangeA * depth + InverseDepthRangeB, 0.0, 1.0);
|
||||||
|
|
Loading…
Reference in a new issue