OpenGL 4.0 GLSL 用单光源 实现逐顶点 漫反射光照模型

漫反射光照模型是:在所有方向上反射的光照强度相等,光照射到物体表面上一部分会被吸收而另一部分在其他方向上散射。一个典型的漫反射表面是没有光泽的,而没有被照射的地方是黑色的。


下面显示了一个漫反射光照模型

OpenGL 4.0 GLSL 用单光源 实现逐顶点 漫反射光照模型_第1张图片


漫反射的数学模型包含两个向量:从物体表面的点到光源的的向量S 和 物体表面的某一点的法线向量N。如图:

OpenGL 4.0 GLSL 用单光源 实现逐顶点 漫反射光照模型_第2张图片


到达物体表面的光照强度很大一部分依赖于物体表面的朝向,当物体的法线方向和光照方向平行  则光照强度最大,当光照方向和这点的法线垂直 则光照强度为0。在这 中间

光照强度同 N与S的余弦值程比例,因此 我们可以用S与N的点积来来表达照射到物体表面的光照强度


Ld 是光源的光照密度,s和n都是单位向量


前面说过  在光被射入到人眼中前 有一部分光被物体吸收  ,设光的反射系数为Kd 则  最终射入人眼的光照强度为

OpenGL 4.0 GLSL 用单光源 实现逐顶点 漫反射光照模型_第3张图片


漫反射光照模型只和光源的位置和法线有关   而与摄像机(viewer)的位置无关

顶点shader


#version 430

layout (location = 0) in vec3 VertexPosition;
layout (location = 1) in vec3 VertexNormal;

out vec3 LightIntensity;

uniform vec4 LightPosition; // Light position in eye coords.
uniform vec3 Kd;            // Diffuse reflectivity
uniform vec3 Ld;            // Diffuse light intensity

uniform mat4 ModelViewMatrix;
uniform mat3 NormalMatrix;
uniform mat4 ProjectionMatrix;
uniform mat4 MVP;

void main()
{
    vec3 tnorm = normalize( NormalMatrix * VertexNormal);
    vec4 eyeCoords = ModelViewMatrix * vec4(VertexPosition,1.0);
    vec3 s = normalize(vec3(LightPosition - eyeCoords));

    LightIntensity = Ld * Kd * max( dot( s, tnorm ), 0.0 );

    gl_Position = MVP * vec4(VertexPosition,1.0);
}


片元shader

#version 430

in vec3 LightIntensity;

layout( location = 0 ) out vec4 FragColor;

void main() {
    FragColor = vec4(LightIntensity, 1.0);
}



你可能感兴趣的:(OpenGL 4.0 GLSL 用单光源 实现逐顶点 漫反射光照模型)