2022-09-19 18:05:01 +08:00

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;
}
}