|
|
@ -63,7 +63,7 @@ uniform bool simpleWater;
|
|
|
|
varying float euclideanDepth;
|
|
|
|
varying float euclideanDepth;
|
|
|
|
varying float linearDepth;
|
|
|
|
varying float linearDepth;
|
|
|
|
|
|
|
|
|
|
|
|
#define PER_PIXEL_LIGHTING ((@normalMap || @forcePPL) && !@simpleLighting)
|
|
|
|
#define PER_PIXEL_LIGHTING (@normalMap || @forcePPL)
|
|
|
|
|
|
|
|
|
|
|
|
#if !PER_PIXEL_LIGHTING
|
|
|
|
#if !PER_PIXEL_LIGHTING
|
|
|
|
centroid varying vec3 passLighting;
|
|
|
|
centroid varying vec3 passLighting;
|
|
|
@ -170,9 +170,6 @@ void main()
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
float shadowing = unshadowedLightRatio(linearDepth);
|
|
|
|
float shadowing = unshadowedLightRatio(linearDepth);
|
|
|
|
#if @simpleLighting
|
|
|
|
|
|
|
|
gl_FragData[0].xyz *= passLighting;
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
vec3 lighting;
|
|
|
|
vec3 lighting;
|
|
|
|
#if !PER_PIXEL_LIGHTING
|
|
|
|
#if !PER_PIXEL_LIGHTING
|
|
|
|
lighting = passLighting + shadowDiffuseLighting * shadowing;
|
|
|
|
lighting = passLighting + shadowDiffuseLighting * shadowing;
|
|
|
@ -183,8 +180,8 @@ void main()
|
|
|
|
lighting = diffuseColor.xyz * diffuseLight + getAmbientColor().xyz * ambientLight + emission;
|
|
|
|
lighting = diffuseColor.xyz * diffuseLight + getAmbientColor().xyz * ambientLight + emission;
|
|
|
|
clampLightingResult(lighting);
|
|
|
|
clampLightingResult(lighting);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
gl_FragData[0].xyz *= lighting;
|
|
|
|
gl_FragData[0].xyz *= lighting;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if @envMap && !@preLightEnv
|
|
|
|
#if @envMap && !@preLightEnv
|
|
|
|
gl_FragData[0].xyz += texture2D(envMap, envTexCoordGen).xyz * envMapColor.xyz * envLuma;
|
|
|
|
gl_FragData[0].xyz += texture2D(envMap, envTexCoordGen).xyz * envMapColor.xyz * envLuma;
|
|
|
@ -210,7 +207,6 @@ void main()
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
gl_FragData[0].xyz += getSpecular(normalize(viewNormal), normalize(passViewPos.xyz), shininess, matSpec) * shadowing;
|
|
|
|
gl_FragData[0].xyz += getSpecular(normalize(viewNormal), normalize(passViewPos.xyz), shininess, matSpec) * shadowing;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if @radialFog
|
|
|
|
#if @radialFog
|
|
|
|
float depth;
|
|
|
|
float depth;
|
|
|
|
// For the less detailed mesh of simple water we need to recalculate depth on per-pixel basis
|
|
|
|
// For the less detailed mesh of simple water we need to recalculate depth on per-pixel basis
|
|
|
|