Merge branch 'actuallynormalnormalz' into 'master'

Reconstruct normal Z *properly*

See merge request OpenMW/openmw!4036
pull/3235/head
psi29a 9 months ago
commit b072b9e54b

@ -77,10 +77,11 @@ void main()
vec3 specularColor = getSpecularColor().xyz; vec3 specularColor = getSpecularColor().xyz;
#if @normalMap #if @normalMap
vec4 normalTex = texture2D(normalMap, normalMapUV); vec4 normalTex = texture2D(normalMap, normalMapUV);
vec3 normal = normalTex.xyz * 2.0 - 1.0;
#if @reconstructNormalZ #if @reconstructNormalZ
normalTex.z = sqrt(1.0 - dot(normalTex.xy, normalTex.xy)); normal.z = sqrt(1.0 - dot(normal.xy, normal.xy));
#endif #endif
vec3 viewNormal = normalToView(normalTex.xyz * 2.0 - 1.0); vec3 viewNormal = normalToView(normal);
specularColor *= normalTex.a; specularColor *= normalTex.a;
#else #else
vec3 viewNormal = normalize(gl_NormalMatrix * passNormal); vec3 viewNormal = normalize(gl_NormalMatrix * passNormal);

@ -60,10 +60,11 @@ void main()
#if @normalMap #if @normalMap
vec4 normalTex = texture2D(normalMap, normalMapUV); vec4 normalTex = texture2D(normalMap, normalMapUV);
vec3 normal = normalTex.xyz * 2.0 - 1.0;
#if @reconstructNormalZ #if @reconstructNormalZ
normalTex.z = sqrt(1.0 - dot(normalTex.xy, normalTex.xy)); normal.z = sqrt(1.0 - dot(normal.xy, normal.xy));
#endif #endif
vec3 viewNormal = normalToView(normalTex.xyz * 2.0 - 1.0); vec3 viewNormal = normalToView(normal);
#else #else
vec3 viewNormal = normalToView(normalize(passNormal)); vec3 viewNormal = normalToView(normalize(passNormal));
#endif #endif

@ -168,10 +168,11 @@ vec2 screenCoords = gl_FragCoord.xy / screenRes;
#if @normalMap #if @normalMap
vec4 normalTex = texture2D(normalMap, normalMapUV + offset); vec4 normalTex = texture2D(normalMap, normalMapUV + offset);
vec3 normal = normalTex.xyz * 2.0 - 1.0;
#if @reconstructNormalZ #if @reconstructNormalZ
normalTex.z = sqrt(1.0 - dot(normalTex.xy, normalTex.xy)); normal.z = sqrt(1.0 - dot(normal.xy, normal.xy));
#endif #endif
vec3 viewNormal = normalToView(normalTex.xyz * 2.0 - 1.0); vec3 viewNormal = normalToView(normal);
#else #else
vec3 viewNormal = normalize(gl_NormalMatrix * passNormal); vec3 viewNormal = normalize(gl_NormalMatrix * passNormal);
#endif #endif

@ -64,10 +64,11 @@ void main()
#if @normalMap #if @normalMap
vec4 normalTex = texture2D(normalMap, adjustedUV); vec4 normalTex = texture2D(normalMap, adjustedUV);
vec3 normal = normalTex.xyz * 2.0 - 1.0;
#if @reconstructNormalZ #if @reconstructNormalZ
normalTex.z = sqrt(1.0 - dot(normalTex.xy, normalTex.xy)); normal.z = sqrt(1.0 - dot(normal.xy, normal.xy));
#endif #endif
vec3 viewNormal = normalToView(normalTex.xyz * 2.0 - 1.0); vec3 viewNormal = normalToView(normal);
#else #else
vec3 viewNormal = normalize(gl_NormalMatrix * passNormal); vec3 viewNormal = normalize(gl_NormalMatrix * passNormal);
#endif #endif

Loading…
Cancel
Save