1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-25 00:23:52 +00:00

Merge pull request #2359 from Capostrophic/shaders

Shader adjustments
This commit is contained in:
Bret Curtis 2019-05-02 13:33:55 +02:00 committed by GitHub
commit 4f7d7fc000
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 16 additions and 4 deletions

View file

@ -63,7 +63,7 @@ vec4 doLighting(vec3 viewPos, vec3 viewNormal, vec4 vertexColor, out vec3 shadow
lightResult.xyz += gl_FrontMaterial.emission.xyz; lightResult.xyz += gl_FrontMaterial.emission.xyz;
#if @clamp #if @clamp
lightResult = clamp(lightResult, vec4(0.0, 0.0, 0.0, 0.0), vec4(1.0, 1.0, 1.0, 1.0)); lightResult = clamp(lightResult, vec4(0.0), vec4(1.0));
#else #else
lightResult = max(lightResult, 0.0); lightResult = max(lightResult, 0.0);
#endif #endif

View file

@ -98,7 +98,7 @@ void main()
#if @diffuseMap #if @diffuseMap
gl_FragData[0] = texture2D(diffuseMap, adjustedDiffuseUV); gl_FragData[0] = texture2D(diffuseMap, adjustedDiffuseUV);
#else #else
gl_FragData[0] = vec4(1.0, 1.0, 1.0, 1.0); gl_FragData[0] = vec4(1.0);
#endif #endif
#if @detailMap #if @detailMap
@ -117,7 +117,13 @@ void main()
float shadowing = unshadowedLightRatio(); float shadowing = unshadowedLightRatio();
#if !PER_PIXEL_LIGHTING #if !PER_PIXEL_LIGHTING
#if @clamp
gl_FragData[0] *= clamp(lighting + vec4(shadowDiffuseLighting * shadowing, 0), vec4(0.0), vec4(1.0));
#else
gl_FragData[0] *= lighting + vec4(shadowDiffuseLighting * shadowing, 0); gl_FragData[0] *= lighting + vec4(shadowDiffuseLighting * shadowing, 0);
#endif
#else #else
gl_FragData[0] *= doLighting(passViewPos, normalize(viewNormal), passColor, shadowing); gl_FragData[0] *= doLighting(passViewPos, normalize(viewNormal), passColor, shadowing);
#endif #endif

View file

@ -69,7 +69,13 @@ void main()
float shadowing = unshadowedLightRatio(); float shadowing = unshadowedLightRatio();
#if !PER_PIXEL_LIGHTING #if !PER_PIXEL_LIGHTING
#if @clamp
gl_FragData[0] *= clamp(lighting + vec4(shadowDiffuseLighting * shadowing, 0), vec4(0.0), vec4(1.0));
#else
gl_FragData[0] *= lighting + vec4(shadowDiffuseLighting * shadowing, 0); gl_FragData[0] *= lighting + vec4(shadowDiffuseLighting * shadowing, 0);
#endif
#else #else
gl_FragData[0] *= doLighting(passViewPos, normalize(viewNormal), passColor, shadowing); gl_FragData[0] *= doLighting(passViewPos, normalize(viewNormal), passColor, shadowing);
#endif #endif

View file

@ -170,7 +170,7 @@ void main(void)
vec2 screenCoords = screenCoordsPassthrough.xy / screenCoordsPassthrough.z; vec2 screenCoords = screenCoordsPassthrough.xy / screenCoordsPassthrough.z;
screenCoords.y = (1.0-screenCoords.y); screenCoords.y = (1.0-screenCoords.y);
vec2 nCoord = vec2(0.0,0.0); vec2 nCoord = vec2(0.0);
#define waterTimer osg_SimulationTime #define waterTimer osg_SimulationTime
@ -186,7 +186,7 @@ void main(void)
if (rainIntensity > 0.01) if (rainIntensity > 0.01)
rainRipple = rainCombined(position.xy / 1000.0,waterTimer) * clamp(rainIntensity,0.0,1.0); rainRipple = rainCombined(position.xy / 1000.0,waterTimer) * clamp(rainIntensity,0.0,1.0);
else else
rainRipple = vec4(0.0,0.0,0.0,0.0); rainRipple = vec4(0.0);
vec3 rippleAdd = rainRipple.xyz * rainRipple.w * 10.0; vec3 rippleAdd = rainRipple.xyz * rainRipple.w * 10.0;