2012-05-03 21:33:13 -04:00
|
|
|
// Shader based on work by Fabien Sanglard
|
|
|
|
// Released under the terms of CC-BY 3.0
|
|
|
|
|
|
|
|
varying vec3 lightVec;
|
|
|
|
varying vec3 halfVec;
|
|
|
|
varying vec3 eyeVec;
|
|
|
|
varying vec4 coord;
|
|
|
|
uniform vec3 lightdir;
|
|
|
|
|
|
|
|
void main()
|
|
|
|
{
|
|
|
|
|
|
|
|
gl_TexCoord[0] = gl_MultiTexCoord0;
|
2013-06-18 10:35:29 -04:00
|
|
|
|
2012-05-03 21:33:13 -04:00
|
|
|
// Building the matrix Eye Space -> Tangent Space
|
|
|
|
vec3 n = normalize (gl_NormalMatrix * gl_Normal);
|
|
|
|
// gl_MultiTexCoord1.xyz
|
|
|
|
vec3 t = normalize (gl_NormalMatrix * vec3(1.0, 0.0, 0.0)); // tangent
|
|
|
|
vec3 b = cross (n, t);
|
2013-06-18 10:35:29 -04:00
|
|
|
|
2012-05-03 21:33:13 -04:00
|
|
|
vec3 vertexPosition = vec3(gl_ModelViewMatrix * gl_Vertex);
|
2013-06-18 10:35:29 -04:00
|
|
|
|
2012-05-03 21:33:13 -04:00
|
|
|
// transform light and half angle vectors by tangent basis
|
|
|
|
vec3 v;
|
|
|
|
v.x = dot (lightdir, t);
|
|
|
|
v.y = dot (lightdir, b);
|
|
|
|
v.z = dot (lightdir, n);
|
|
|
|
lightVec = normalize (v);
|
|
|
|
|
|
|
|
vertexPosition = normalize(vertexPosition);
|
2013-06-18 10:35:29 -04:00
|
|
|
|
|
|
|
eyeVec = normalize(-vertexPosition); // we are in Eye Coordinates, so EyePos is (0,0,0)
|
2012-05-03 21:33:13 -04:00
|
|
|
|
|
|
|
// Normalize the halfVector to pass it to the fragment shader
|
|
|
|
|
|
|
|
// No need to divide by two, the result is normalized anyway.
|
2013-06-18 10:35:29 -04:00
|
|
|
// vec3 halfVector = normalize((vertexPosition + lightDir) / 2.0);
|
2012-05-03 21:33:13 -04:00
|
|
|
vec3 halfVector = normalize(vertexPosition + lightdir);
|
|
|
|
v.x = dot (halfVector, t);
|
|
|
|
v.y = dot (halfVector, b);
|
|
|
|
v.z = dot (halfVector, n);
|
|
|
|
|
|
|
|
// No need to normalize, t,b,n and halfVector are normal vectors.
|
|
|
|
//normalize (v);
|
2013-06-18 10:35:29 -04:00
|
|
|
halfVec = v ;
|
|
|
|
|
2012-05-03 21:33:13 -04:00
|
|
|
gl_Position = ftransform();
|
|
|
|
coord = gl_Position;
|
|
|
|
}
|