mirror of https://github.com/kivy/kivy.git
46 lines
1.2 KiB
Plaintext
46 lines
1.2 KiB
Plaintext
|
/* simple.glsl
|
||
|
|
||
|
simple diffuse lighting based on laberts cosine law; see e.g.:
|
||
|
http://en.wikipedia.org/wiki/Lambertian_reflectance
|
||
|
http://en.wikipedia.org/wiki/Lambert%27s_cosine_law
|
||
|
*/
|
||
|
|
||
|
---VERTEX SHADER-------------------------------------------------------
|
||
|
|
||
|
attribute vec3 v_pos;
|
||
|
attribute vec3 v_normal;
|
||
|
|
||
|
uniform mat4 modelview_mat;
|
||
|
uniform mat4 projection_mat;
|
||
|
|
||
|
varying vec4 normal_vec;
|
||
|
varying vec4 vertex_pos;
|
||
|
|
||
|
void main (void) {
|
||
|
//compute vertex position in eye_sapce and normalize normal vector
|
||
|
vec4 pos = modelview_mat * vec4(v_pos,1.0);
|
||
|
vertex_pos = pos;
|
||
|
normal_vec = vec4(v_normal,0.0);
|
||
|
gl_Position = projection_mat * pos;
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
---FRAGMENT SHADER-----------------------------------------------------
|
||
|
|
||
|
uniform mat4 normal_mat;
|
||
|
|
||
|
varying vec4 normal_vec;
|
||
|
varying vec4 vertex_pos;
|
||
|
|
||
|
void main (void){
|
||
|
//correct normal, and compute light vector (assume light at the eye)
|
||
|
vec4 v_normal = normalize( vec4(mat3(normal_mat) * vec3(normal_vec), 0.0) ) ;
|
||
|
vec4 v_light = normalize( vec4(0,0,0,1) - vertex_pos );
|
||
|
|
||
|
//reflectance based on lamberts law of cosine
|
||
|
float theta = clamp(dot(v_normal, v_light), 0.0, 1.0);
|
||
|
gl_FragColor = vec4(theta, theta, theta, 1.0);
|
||
|
}
|
||
|
|