2016-02-19 01:30:15 +01:00
#version 120
varying vec2 uv;
varying float depth;
#define PER_PIXEL_LIGHTING (@normalMap || @forcePPL)
#if !PER_PIXEL_LIGHTING
varying vec4 lighting;
2017-09-21 01:59:02 +01:00
varying vec3 shadowDiffuseLighting;
2016-02-19 01:30:15 +01:00
#else
varying vec4 passColor;
#endif
2016-02-20 19:54:47 +01:00
varying vec3 passViewPos;
2016-03-22 21:00:31 +01:00
varying vec3 passNormal;
2016-02-19 01:30:15 +01:00
2017-09-21 00:25:48 +01:00
varying vec4 shadowSpaceCoords;
2016-02-19 01:30:15 +01:00
#include "lighting.glsl"
void main(void)
{
gl_Position = gl_ModelViewProjectionMatrix * gl_Vertex;
depth = gl_Position.z;
vec4 viewPos = (gl_ModelViewMatrix * gl_Vertex);
gl_ClipVertex = viewPos;
#if !PER_PIXEL_LIGHTING
2016-03-22 21:00:31 +01:00
vec3 viewNormal = normalize((gl_NormalMatrix * gl_Normal).xyz);
2017-09-21 01:59:02 +01:00
lighting = doLighting(viewPos.xyz, viewNormal, gl_Color, shadowDiffuseLighting);
2016-02-19 01:30:15 +01:00
#else
passColor = gl_Color;
#endif
2016-03-22 21:00:31 +01:00
passNormal = gl_Normal.xyz;
2016-02-20 19:54:47 +01:00
passViewPos = viewPos.xyz;
2016-02-19 01:30:15 +01:00
uv = gl_MultiTexCoord0.xy;
2017-09-21 00:25:48 +01:00
// This matrix has the opposite handedness to the others used here, so multiplication must have the vector to the left. Alternatively it could be transposed after construction, but that's extra work for the GPU just to make the code look a tiny bit cleaner.
mat4 eyePlaneMat = mat4(gl_EyePlaneS[1], gl_EyePlaneT[1], gl_EyePlaneR[1], gl_EyePlaneQ[1]);
shadowSpaceCoords = viewPos * eyePlaneMat;
2016-02-19 01:30:15 +01:00
}