初次提交
This commit is contained in:
2015
第15章 真实光学环境的模拟/Sample15_4/assets/ball.obj
Normal file
2015
第15章 真实光学环境的模拟/Sample15_4/assets/ball.obj
Normal file
File diff suppressed because it is too large
Load Diff
8
第15章 真实光学环境的模拟/Sample15_4/assets/frag_tex.sh
Normal file
8
第15章 真实光学环境的模拟/Sample15_4/assets/frag_tex.sh
Normal file
@@ -0,0 +1,8 @@
|
||||
precision mediump float;
|
||||
varying vec2 vTextureCoord; //接收从顶点着色器过来的参数
|
||||
uniform sampler2D sTexture;//纹理内容数据
|
||||
void main()
|
||||
{
|
||||
//给此片元从纹理中采样出颜色值
|
||||
gl_FragColor = texture2D(sTexture, vTextureCoord);
|
||||
}
|
||||
19
第15章 真实光学环境的模拟/Sample15_4/assets/frag_tex_cube.sh
Normal file
19
第15章 真实光学环境的模拟/Sample15_4/assets/frag_tex_cube.sh
Normal file
@@ -0,0 +1,19 @@
|
||||
precision mediump float;
|
||||
uniform samplerCube sTexture;//纹理内容数据
|
||||
varying vec3 eyeVary; //接收从顶点着色器过来的视线向量
|
||||
varying vec3 newNormalVary; //接收从顶点着色器过来的变换后法向量
|
||||
vec4 zs( //根据法向量、视线向量及斯涅尔定律计算立方图纹理采样的方法
|
||||
in float zsl //折射率
|
||||
){
|
||||
vec3 vTextureCoord=refract(-eyeVary,newNormalVary,zsl);//根据斯涅尔定律计算
|
||||
vec4 finalColor=textureCube(sTexture, vTextureCoord); //进行立方图纹理采样
|
||||
return finalColor;
|
||||
}
|
||||
void main(){
|
||||
vec4 finalColor=vec4(0.0,0.0,0.0,0.0);
|
||||
//由于有色散RGB三个色彩通道单独计算折射
|
||||
finalColor.r=zs(0.97).r;
|
||||
finalColor.g=zs(0.955).g;
|
||||
finalColor.b=zs(0.94).b;
|
||||
gl_FragColor=finalColor;
|
||||
}
|
||||
9
第15章 真实光学环境的模拟/Sample15_4/assets/vertex_tex.sh
Normal file
9
第15章 真实光学环境的模拟/Sample15_4/assets/vertex_tex.sh
Normal file
@@ -0,0 +1,9 @@
|
||||
uniform mat4 uMVPMatrix; //总变换矩阵
|
||||
attribute vec3 aPosition; //顶点位置
|
||||
attribute vec2 aTexCoor; //顶点纹理坐标
|
||||
varying vec2 vTextureCoord; //用于传递给片元着色器的变量
|
||||
void main()
|
||||
{
|
||||
gl_Position = uMVPMatrix * vec4(aPosition,1); //根据总变换矩阵计算此次绘制此顶点位置
|
||||
vTextureCoord = aTexCoor;//将接收的纹理坐标传递给片元着色器
|
||||
}
|
||||
18
第15章 真实光学环境的模拟/Sample15_4/assets/vertex_tex_cube.sh
Normal file
18
第15章 真实光学环境的模拟/Sample15_4/assets/vertex_tex_cube.sh
Normal file
@@ -0,0 +1,18 @@
|
||||
uniform mat4 uMVPMatrix; //总变换矩阵
|
||||
uniform mat4 uMMatrix; //变换矩阵
|
||||
uniform vec3 uCamera; //摄像机位置
|
||||
attribute vec3 aPosition; //顶点位置
|
||||
attribute vec3 aNormal; //顶点法向量
|
||||
varying vec3 eyeVary; //用于传递给片元着色器的视线向量
|
||||
varying vec3 newNormalVary; //用于传递给片元着色器的变换后法向量
|
||||
void main() {
|
||||
gl_Position = uMVPMatrix * vec4(aPosition,1); //根据总变换矩阵计算此次绘制此顶点位置
|
||||
//计算变换后的法向量并规格化
|
||||
vec3 normalTarget=aPosition+aNormal;
|
||||
vec3 newNormal=(uMMatrix*vec4(normalTarget,1)).xyz-(uMMatrix*vec4(aPosition,1)).xyz;
|
||||
newNormal=normalize(newNormal);
|
||||
newNormalVary=newNormal;//将变换后的法向量传递给片元着色器
|
||||
//计算从观察点到摄像机的向量(视线向量)
|
||||
vec3 eye = normalize(uCamera-(uMMatrix*vec4(aPosition,1)).xyz);
|
||||
eyeVary=eye;//将视线向量传递给片元着色器
|
||||
}
|
||||
Reference in New Issue
Block a user