Cg入门21:Fragment shader - 2D纹理采样
Posted Potter
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Cg入门21:Fragment shader - 2D纹理采样相关的知识,希望对你有一定的参考价值。
体纹理:是啥?
tex2D 以前只能在Fragment程序中纹理采样
UV坐标系:其实点为左下角,范围为【0,1】,U为x轴,V为y轴
data:image/s3,"s3://crabby-images/261a0/261a04a4a3e9fbc0f98b87271fb318c1acbeb026" alt="技术分享"
data:image/s3,"s3://crabby-images/9c64c/9c64c4ae0801e560fa8dedcc80f7df4f8c057cf4" alt="技术分享".png)
Texture.wrapMode 循环模式:
TextureWrapMode.Clamp:设置纹理充满拉伸使用
TextureWrapMode.Repeat:纹理重复平铺使用
如果采用Repeat,那么等于U>=1的情况就会用纹理图在右边在平铺一张图
Texture.filterMode 过滤模式:
Point:像素过滤(不进行过滤 )
Bilinear:双线性
Trilinear:三线的
UV纹理采样:
UV 纹理
data:image/s3,"s3://crabby-images/805cc/805cc0e63b0b9e02ac0ec0395f0f6fbda568d914" alt="技术分享"
data:image/s3,"s3://crabby-images/b84e0/b84e03e1bf62c0cc2627722cd10fac1417d56e9f" alt="技术分享".png)
贴图后效果:立体空间的UV坐标为左上角,U为水平向右方向,V为垂直向下方向 ,默认范围[0,1]
data:image/s3,"s3://crabby-images/d7b72/d7b72f22a7691239195319f72ea496c00174cc9d" alt="技术分享".png)
data:image/s3,"s3://crabby-images/4496d/4496d2feb8e3caf71800ae56e729c21cf07704b9" alt="技术分享"
源代码:
Shader "Sbin/TexShader" { Properties { _MainTex ("Texture", 2D) = "white" {} _U("U",range(-0001,0.001)) = 0 _V("V",range(0,1)) = 0 } SubShader { Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc" sampler2D _MainTex; float _U; float _V; 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 = v.texcoord.xy; return o; } fixed4 frag (v2f v) : COLOR { fixed4 col = tex2D(_MainTex, v.uv);//第一个参数:纹理,第二个参数UV向量 return col; } ENDCG } } }
纹理平铺缩放和偏移:
data:image/s3,"s3://crabby-images/0193c/0193c6ae68437c8dfb41c1fbab9f7a1d7803bd11" alt="技术分享".png)
data:image/s3,"s3://crabby-images/df08f/df08f4e095acfeeabe0ba0a0019c25b79bab215b" alt="技术分享"
Tiling :缩放模型UV纹理采样坐标;比如:Tiling x=2,表示把模型UV坐标的U扩大2倍,U范围值变成2,纹理如果WrapMode选择Repeat,那么U轴方向就会纹理采样两次。V轴同理
data:image/s3,"s3://crabby-images/07fca/07fca5b8cca51822d7227e109000683c2b4523c1" alt="技术分享"
data:image/s3,"s3://crabby-images/15e50/15e5091e68eb99a919a6e403f575f40890427b30" alt="技术分享".png)
Offset:偏移模型UV纹理采样坐标;比如:Offset x = 0.1,表示把模型UV坐标往左编译,然后再采样UV纹理贴图。
data:image/s3,"s3://crabby-images/61aef/61aeff4a791b981d4367ac645632b6f39449a505" alt="技术分享"
data:image/s3,"s3://crabby-images/ff8ec/ff8eca5840eccd51a896094995f3c514952ccb7a" alt="技术分享".png)
以上两种操作导致如下效果:
data:image/s3,"s3://crabby-images/71243/7124371b43f3c46c1ff361aa5d62a944fcb09007" alt="技术分享"
data:image/s3,"s3://crabby-images/6c7c9/6c7c994629f9e832a79daef516f2189498619d44" alt="技术分享".png)
以上是关于Cg入门21:Fragment shader - 2D纹理采样的主要内容,如果未能解决你的问题,请参考以下文章
Cg入门25: Fragment shader – UV动画(模糊)
Cg入门24: Fragment shader – UV动画(波纹)
Cg入门17:Fragment shader - 片段级光照(添加阴影)
Cg入门16:Fragment shader - 片段级光照