25 lines
1.3 KiB
Bash
25 lines
1.3 KiB
Bash
precision mediump float; //设置默认精度
|
|
uniform sampler2D sTexture; //纹理内容数据
|
|
varying vec4 ambient; //接收从顶点着色器传递过来的环境光参数
|
|
varying vec4 diffuse; //接收从顶点着色器传递过来的散射光参数
|
|
varying vec4 specular; //接收从顶点着色器传递过来的镜面光参数
|
|
varying vec4 vPosition; //接收从顶点着色器传递过来的片元位置
|
|
uniform highp mat4 uMVPMatrixGY; //光源位置处虚拟摄像机观察及投影组合矩阵
|
|
void main() {
|
|
//将片元的位置投影到光源处虚拟摄像机的近平面上
|
|
vec4 gytyPosition=uMVPMatrixGY * vec4(vPosition.xyz,1);
|
|
gytyPosition=gytyPosition/gytyPosition.w; //进行透视除法
|
|
float s=gytyPosition.s+0.5; //将投影后的坐标换算为纹理坐标
|
|
float t=gytyPosition.t+0.5;
|
|
vec4 finalColor=vec4(0.8,0.8,0.8,1.0); //物体本身的颜色
|
|
if(s>=0.0&&s<=1.0&&t>=0.0&&t<=1.0){ //若纹理坐标在合法范围内则考虑投影贴图
|
|
vec4 projColor=texture2D(sTexture, vec2(s,t)); //对投影纹理图进行采样
|
|
vec4 specularTemp=projColor*specular; //计算投影贴图对镜面光的影响
|
|
vec4 diffuseTemp=projColor*diffuse; //计算投影贴图对散射光的影响
|
|
//计算最终片元颜色
|
|
gl_FragColor = finalColor*ambient+finalColor*specularTemp+finalColor*diffuseTemp;
|
|
} else {//计算最终片元颜色
|
|
gl_FragColor = finalColor*ambient+finalColor*specular+finalColor*diffuse;
|
|
}
|
|
}
|