OGLRender:

- Fix depth buffer calculations. Fixes lots of graphical glitches in “Harry Potter and the Order of the Phoenix” and many other 3D rendering cases.
This commit is contained in:
rogerman 2015-03-26 10:30:44 +00:00
parent 9b2d36df0c
commit 69ec85e624
2 changed files with 7 additions and 25 deletions

View File

@ -266,7 +266,7 @@ static const char *fragmentShader_100 = {"\
uniform bool hasTexture; \n\ uniform bool hasTexture; \n\
uniform int polygonMode; \n\ uniform int polygonMode; \n\
uniform int toonShadingMode; \n\ uniform int toonShadingMode; \n\
uniform int oglWBuffer; \n\ uniform bool oglWBuffer; \n\
uniform bool enableAlphaTest; \n\ uniform bool enableAlphaTest; \n\
uniform float alphaTestRef; \n\ uniform float alphaTestRef; \n\
\n\ \n\
@ -331,16 +331,7 @@ static const char *fragmentShader_100 = {"\
discard; \n\ discard; \n\
} \n\ } \n\
\n\ \n\
if (oglWBuffer == 1) \n\ gl_FragDepth = (oglWBuffer) ? vtxPosition.w/4096.0 : vtxPosition.z/4096.0; \n\
{ \n\
/* The w component is in 1.12 format, normalize it to [-1;+1] */ \
gl_FragDepth = (vtxPosition.w / 4096.0) * 0.5 + 0.5; \n\
} \n\
else \n\
{ \n\
gl_FragDepth = (vtxPosition.z / vtxPosition.w) * 0.5 + 0.5; \n\
} \n\
\n\
gl_FragColor = fragColor; \n\ gl_FragColor = fragColor; \n\
} \n\ } \n\
"}; "};
@ -1833,7 +1824,7 @@ Render3DError OpenGLRenderer_1_2::BeginRender(const GFX3D_State *renderState)
glUniform1i(OGLRef.uniformEnableAlphaTest, renderState->enableAlphaTest ? GL_TRUE : GL_FALSE); glUniform1i(OGLRef.uniformEnableAlphaTest, renderState->enableAlphaTest ? GL_TRUE : GL_FALSE);
glUniform1f(OGLRef.uniformAlphaTestRef, divide5bitBy31_LUT[renderState->alphaTestRef]); glUniform1f(OGLRef.uniformAlphaTestRef, divide5bitBy31_LUT[renderState->alphaTestRef]);
glUniform1i(OGLRef.uniformToonShadingMode, renderState->shading); glUniform1i(OGLRef.uniformToonShadingMode, renderState->shading);
glUniform1i(OGLRef.uniformWBuffer, renderState->wbuffer); glUniform1i(OGLRef.uniformWBuffer, renderState->wbuffer ? GL_TRUE : GL_FALSE);
} }
else else
{ {
@ -2337,7 +2328,7 @@ Render3DError OpenGLRenderer_1_2::Reset()
glUniform1i(OGLRef.uniformHasTexture, GL_FALSE); glUniform1i(OGLRef.uniformHasTexture, GL_FALSE);
glUniform1i(OGLRef.uniformPolygonMode, 0); glUniform1i(OGLRef.uniformPolygonMode, 0);
glUniform1i(OGLRef.uniformToonShadingMode, 0); glUniform1i(OGLRef.uniformToonShadingMode, 0);
glUniform1i(OGLRef.uniformWBuffer, 0); glUniform1i(OGLRef.uniformWBuffer, GL_FALSE);
glUniform1i(OGLRef.uniformEnableAlphaTest, GL_TRUE); glUniform1i(OGLRef.uniformEnableAlphaTest, GL_TRUE);
glUniform1f(OGLRef.uniformAlphaTestRef, 0.0f); glUniform1f(OGLRef.uniformAlphaTestRef, 0.0f);
} }
@ -3002,7 +2993,7 @@ Render3DError OpenGLRenderer_2_0::BeginRender(const GFX3D_State *renderState)
glUniform1i(OGLRef.uniformEnableAlphaTest, renderState->enableAlphaTest ? GL_TRUE : GL_FALSE); glUniform1i(OGLRef.uniformEnableAlphaTest, renderState->enableAlphaTest ? GL_TRUE : GL_FALSE);
glUniform1f(OGLRef.uniformAlphaTestRef, divide5bitBy31_LUT[renderState->alphaTestRef]); glUniform1f(OGLRef.uniformAlphaTestRef, divide5bitBy31_LUT[renderState->alphaTestRef]);
glUniform1i(OGLRef.uniformToonShadingMode, renderState->shading); glUniform1i(OGLRef.uniformToonShadingMode, renderState->shading);
glUniform1i(OGLRef.uniformWBuffer, renderState->wbuffer); glUniform1i(OGLRef.uniformWBuffer, renderState->wbuffer ? GL_TRUE : GL_FALSE);
if(renderState->enableAlphaBlending) if(renderState->enableAlphaBlending)
{ {

View File

@ -114,7 +114,7 @@ static const char *fragmentShader_150 = {"\
uniform bool hasTexture; \n\ uniform bool hasTexture; \n\
uniform int polygonMode; \n\ uniform int polygonMode; \n\
uniform int toonShadingMode; \n\ uniform int toonShadingMode; \n\
uniform int oglWBuffer; \n\ uniform bool oglWBuffer; \n\
uniform bool enableAlphaTest; \n\ uniform bool enableAlphaTest; \n\
uniform float alphaTestRef; \n\ uniform float alphaTestRef; \n\
\n\ \n\
@ -181,16 +181,7 @@ static const char *fragmentShader_150 = {"\
discard; \n\ discard; \n\
} \n\ } \n\
\n\ \n\
if (oglWBuffer == 1) \n\ gl_FragDepth = (oglWBuffer) ? vtxPosition.w/4096.0 : vtxPosition.z/4096.0; \n\
{ \n\
/* The w component is in 1.12 format, normalize it to [-1;+1] */ \
gl_FragDepth = (vtxPosition.w / 4096.0) * 0.5 + 0.5; \n\
} \n\
else \n\
{ \n\
gl_FragDepth = (vtxPosition.z / vtxPosition.w) * 0.5 + 0.5; \n\
} \n\
\n\
outFragColor = fragColor; \n\ outFragColor = fragColor; \n\
} \n\ } \n\
"}; "};