ShaderLab学习小结(九)简单的可赋纹理贴图的顶点片断shader
2018-01-29 17:29
896 查看
有一张砖墙的图片
将它作为纹理贴图赋给材质,将此材质赋给场景中的cube
不涉及光照啊阴影什么的,就是赋个贴图,并不复杂
Shader代码:
_MainTex("Main Tex", 2d) = ""{}
类型是2d。
sampler2D _MainTex;
类型是sampler2D,注意D大写。
结构体中定义一个float2,记录uv信息
float2 uv:TEXCOORD0;
分配TEXCOORD0
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
此处TRANSFORM_TEX定义在unitycg.cginc中,找到它定义的地方
两个参数:tex和name
tex就来自于v.texcoord;
name这里就是_MainTex。
注意:name##_ST.xy和name##_ST.zw
name##_ST也就是_MainTex_ST,而且有xyzw,是四维向量,这个也需要声明一下
不声明会报错
那么这个处理是干什么用的呢?
当我们在shader的Properties块中定义了贴图之后,在unity的Inspector面板上查看材质就会自动带上Tilling和Offset两个属性
这两个都是2维向量,Tilling代表两个方向上的,嗯,平铺吧,Offset是两个方向上的位移
但是,shader中必须做TRANSFORM_TEX,才能使这两个属性正确生效,这就是TRANSFORM_TEX的用处。
CG函数 tex2D(sampler2D tex, float2 s),得到四维向量颜色。
本例中
fixed4 col = tex2D(_MainTex, IN.uv);
将它作为纹理贴图赋给材质,将此材质赋给场景中的cube
不涉及光照啊阴影什么的,就是赋个贴图,并不复杂
Shader代码:
Shader "Custom/TestVFTexture" { Properties{ _MainTex("Main Tex", 2d) = ""{} } SubShader { pass { CGPROGRAM #pragma vertex vert #pragma fragment frag #include "unitycg.cginc" sampler2D _MainTex; float4 _MainTex_ST; struct v2f { float4 pos:POSITION; float2 uv:TEXCOORD0; }; v2f vert(appdata_base v) { v2f o; o.pos = mul(UNITY_MATRIX_MVP, v.vertex); o.uv = TRANSFORM_TEX(v.texcoord, _MainTex); return o; } fixed4 frag(v2f IN):COLOR { fixed4 col = tex2D(_MainTex, IN.uv); return col; } ENDCG } } }
1
既然要赋纹理,在Properties块中当然要定义一个变量存纹理_MainTex("Main Tex", 2d) = ""{}
类型是2d。
2
同样,在CG程序中要声明才能使用。sampler2D _MainTex;
类型是sampler2D,注意D大写。
结构体中定义一个float2,记录uv信息
float2 uv:TEXCOORD0;
分配TEXCOORD0
3
在顶点程序中处理这个uvo.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
此处TRANSFORM_TEX定义在unitycg.cginc中,找到它定义的地方
// Transforms 2D UV by scale/bias property #define TRANSFORM_TEX(tex,name) (tex.xy * name##_ST.xy + name##_ST.zw)
两个参数:tex和name
tex就来自于v.texcoord;
name这里就是_MainTex。
注意:name##_ST.xy和name##_ST.zw
name##_ST也就是_MainTex_ST,而且有xyzw,是四维向量,这个也需要声明一下
sampler2D _MainTex; float4 _MainTex_ST;
不声明会报错
那么这个处理是干什么用的呢?
当我们在shader的Properties块中定义了贴图之后,在unity的Inspector面板上查看材质就会自动带上Tilling和Offset两个属性
这两个都是2维向量,Tilling代表两个方向上的,嗯,平铺吧,Offset是两个方向上的位移
但是,shader中必须做TRANSFORM_TEX,才能使这两个属性正确生效,这就是TRANSFORM_TEX的用处。
4
片断程序中对贴图计算相应的颜色CG函数 tex2D(sampler2D tex, float2 s),得到四维向量颜色。
本例中
fixed4 col = tex2D(_MainTex, IN.uv);
5
返回颜色相关文章推荐
- ShaderLab学习小结(十)简单的支持光照贴图的shader
- ShaderLab学习小结(十五)法线贴图的简单Shader
- ShaderLab学习小结(一)最简化的顶点片断Shader
- ShaderLab学习小结(十二)简单的半透明shader
- Shader学习 基于vert/frag顶点片段级的纹理采样 光照贴图实现
- ShaderLab学习小结(八)在标准表面shader中加入顶点着色器函数
- ShaderLab学习小结(四)简单产生阴影
- ShaderLab学习小结(二)通过Shader变换物体形状
- ShaderLab学习小结(十一)贴图模糊效果
- shader学习基础之十一实现纹理的缩放平移和旋转,以及用c#代码合并两种贴图并且控制位置
- UnityShader入门精要学习笔记(十七):顶点动画
- Shader中贴图知识汇总: 漫反射贴图、凹凸贴图、高光贴图、 AO贴图、环境贴图、 光照纹理及细节贴图
- ogre3D学习基础2 -- 顶点程序与片断程序
- Sandy引擎学习笔记:swf影片剪辑纹理贴图
- 【Unity Shaders】学习笔记——SurfaceShader(七)法线贴图
- Swift 学习小结:简单值 及流程控制
- OpenGL立方体在世界坐标系中_缩放_旋转_平移_顶点片源着色器_光照作用_棋盘纹理贴图
- Java多线程学习简单小结
- ShaderLab学习小结(五)接收平行光阴影
- UnityShader入门精要学习笔记(十七):顶点动画