关于Unity中顶点片元Shader实例
补充
float4 fixed4 _Time
1: float4是内置向量 (x, y, z, w); float4 a; 访问单独成员a.x, a.y, a.z, a.w;
2: fixed4 是内置向量(r, g, b, a); fixed4 c; color.r, color.g, color.b, color.a;
3: float3是内置向量(x, y, z);
4: fixed3 是内置向量(r, g, b);
5: float2 是内置向量(x, y);
6: _Time: 自场景加载开始所经过的时间t,4个分量分别是 (t/20, t, t*2, t*3);
7: _SinTime: t 是时间的正弦值,4个分量分别是 (t/8, t/4, t/2, t);
8: _CosTime: t 是时间的余弦值,4个分量分别是 (t/8, t/4, t/2, t);
9: unity_DeltaTime: dt 是时间增量,4个分量的值(dt, 1/dt, smoothDt, 1/smoothDt),平滑时间,防止时间间隔起伏太大;
正弦波实例
1.创建Unity工程目录
2.创建一个节点plane
3.在resources文件夹下面创建shaders文件夹
4.打开shaders文件夹,创建一个用于顶点片元着色的shader,create---->shader---->unlit shader,重命名为SinShader
5.打开SinShader
第一步:先把第一行改成Shader "Custom/SinShader",这样才能在编辑器里面显示这个shader
第二步:
Shader "Custom/SinShader"
{
Properties//可以绑定到编辑上面的属性
{
_MainTex ("Texture", 2D) = "white" {}
}
SubShader
{
Tags { "RenderType"="Opaque" }//标记
LOD Pass
{
CGPROGRAM//CG代码的开始
#pragma vertex vert
#pragma fragment frag
#include "UnityCG.cginc" struct appdata
{
float4 vertex : POSITION;//模型顶点的位置
float2 uv : TEXCOORD0;//纹理坐标
}; struct v2f
{
float2 uv : TEXCOORD0;//纹理坐标
float4 vertex : POSITION;//模型顶点的位置
}; sampler2D _MainTex;
float4 _MainTex_ST; v2f vert (appdata v)//对模型的顶点坐标的修改写在这里面
{
v2f o;
float dist = distance(v.vertex.xyz, float3(, , ));//求得模型各个顶点坐标到中心原点的相位距离
float h = sin(dist * + _Time.z) / ;//Time是自场景加载开始所经过的时间,t,4个分量分别是 (t/20, t, t*2, t*3);用这个变量.z表示t*2,时间是不断增加的,但是因为周期性,所以h有一个范围
//调整相位dist可以改变水波的振动幅度从而改变水波形态,直接改变振动幅度(除于5)也可以改变水波形态
o.vertex = mul(unity_ObjectToWorld, v.vertex);//模型顶点坐标转换为世界坐标
o.vertex.y = h;//让模型的y坐标等于h这个范围
o.vertex = mul(unity_WorldToObject, o.vertex);//时间坐标再转换为模型顶点坐标 //这两句不是造成正弦波的语句,是简单的shader模板,一开始写的,把图像贴到模型上
o.vertex = mul(UNITY_MATRIX_MVP, o.vertex);//变换成Unity的MVP,模型坐标转为透视坐标
o.uv = TRANSFORM_TEX(v.uv, _MainTex);//根据顶点的纹理坐标,计算出对应的纹理的真正的UV坐标,有了UV坐标,才能在fixed4 frag (v2f i) : SV_Target里面通过它得到颜色 return o;//这个o其实等下要传给fixed4 frag (v2f i) : SV_Target里面的i
} fixed4 frag (v2f i) : SV_Target//对模型的像素着色的修改写在这里面
{
fixed4 col = tex2D(_MainTex, i.uv);//使用uv坐标,寻址得到颜色,返回颜色,着色到模型上面去,就把贴图给贴上了
return col;
}
ENDCG//CG代码的结束
}
}
}
6.打开shaders文件夹,创建一个材质球叫SinShader,选择shader的属性custom---->SinShader
7.把贴图拖进材质球SinShader
8.给平面plane关联材质球SinShader,平面有了纹理,运行起来像水波
UV动画(捕鱼达人3中使用的技术)
1.把鱼模型(jinqiangyu.FBX,jinqiangyu.png)拖进Hierachy,设置鱼Materials/jinqiangyu的材质球的shader为为mobile diffuse
2.把caustics.png资源拖进resources
3.打开shaders文件夹,创建一个unlit shader,重命名为UVShader
4.打开UVShader
第一步:先把第一行改成Shader "Custom/SinShader",这样才能在编辑器里面显示这个shader
第二步:增加一个纹理的定义
Properties
{
_MainTex ("Texture", 2D) = "white" {}
_SubTex ("Texture", 2D) = "white" {}
}
第三步:
Shader "Custom/UVShader"
{
Properties
{
_MainTex ("Texture", 2D) = "white" {}
_SubTex ("Texture", 2D) = "white" {}//放波光的纹理贴图
} SubShader
{
Tags { "RenderType"="Opaque" }
LOD Pass
{
CGPROGRAM
#pragma vertex vert
#pragma fragment frag #include "UnityCG.cginc" struct appdata
{
float4 vertex : POSITION;
float2 uv : TEXCOORD0;
}; struct v2f
{
float2 uv : TEXCOORD0;
float4 vertex : SV_POSITION;
}; sampler2D _SubTex;//要用就要再声明一下,波光
sampler2D _MainTex;//要用就要再声明一下,鱼 float4 _MainTex_ST; v2f vert (appdata v)//对顶点坐标的修改写在这里面,因为没有修改顶点,所以没有新增什么
{
v2f o;
o.vertex = mul(UNITY_MATRIX_MVP, v.vertex);
o.uv = TRANSFORM_TEX(v.uv, _MainTex); return o;
} fixed4 frag (v2f i) : SV_Target//对像素纹理的修改写在这里面
{
float2 uv_offset = float2(, );
uv_offset.x = _Time.y * 0.25;//不断地获得变化的纹理坐标的x
uv_offset.y = _Time.y * 0.25;//不断地获得变化的纹理坐标的y
// sample the texture
fixed4 linght_color = tex2D(_SubTex, i.uv + uv_offset);//通过uv_offset来让纹理动起来,由于波光纹理属性设置为repeat,所以不用担心图片越界的问题。通过i.uv+uv_offset查找获得波光的纹理
fixed4 col = tex2D(_MainTex, i.uv) + linght_color;//把两张纹理加在一起,为什么用黑色的波光图:因为黑色的值是0,0,0,这里加了也不会改变原来的鱼的整体感觉,正是我们要的效果
return col;
}
ENDCG
}
}
}
4.选择鱼材质球的shader为custom---->UVShader
5.把波光的贴图拖进鱼材质球的另外一个贴图属性
6.运行就可以看见鱼被动态波光笼罩
注意:
遇到函数使用有问题的,打开#include “UnityCG.cginc” Unity-->Edit-->Data-->CGIncludes;查看
关于Unity中顶点片元Shader实例的更多相关文章
- 顶点/片元 shader 总结
Cg顶点程序必须在结构中传递顶点数据.几种常用的顶点结构定义在文件UnityCG.cginc中,有如下三种结构体: 1.appdata_base: 包含顶点位置,法线和一个纹理坐标.2.appdata ...
- 解读Unity中的CG编写Shader系列八(镜面反射)
转自http://www.itnose.net/detail/6117378.html 讨论完漫反射之后,接下来肯定就是镜面反射了 在开始镜面反射shader的coding之前,要扩充一下前面提到的知 ...
- 解读Unity中的CG编写Shader系列三
转自http://www.itnose.net/detail/6096068.html 在上一个例子中,我们得到了由mesh组件传递的信息经过数学转换至合适的颜色区间以颜色的形式着色到物体上.这篇文章 ...
- [转]解读Unity中的CG编写Shader系列9——镜面反射
讨论完漫反射之后,接下来肯定就是镜面反射了在开始镜面反射shader的coding之前,要扩充一下前面提到的知识,加深理解镜面反射与漫反射的区别.注:这篇文章实现的镜面反射是逐顶点着色(per-ver ...
- [转]解读Unity中的CG编写Shader系列3——表面剔除与剪裁模式
在上一个例子中,我们得到了由mesh组件传递的信息经过数学转换至合适的颜色区间以颜色的形式着色到物体上.这篇文章将要在此基础上研究片段的擦除(discarding fragments)和前面剪裁.后面 ...
- 解读Unity中的CG编写Shader系列3——表面剔除与剪裁模式
在上一个样例中,我们得到了由mesh组件传递的信息经过数学转换至合适的颜色区间以颜色的形式着色到物体上. 这篇文章将要在此基础上研究片段的擦除(discarding fragments)和前面剪裁.后 ...
- 解读Unity中的CG编写Shader系列七(不透明度与混合)
转自http://www.itnose.net/detail/6098539.html 1.不透明度 当我们要将两个半透的纹理贴图到一个材质球上的时候就遇到混合的问题,由于前面的知识我们已经知道了片段 ...
- Unity中的CG编写Shader系列(Blend)
1.不透明度 当我们要将两个半透的纹理贴图到一个材质球上的时候就遇到混合的问题,由于前面的知识我们已经知道了片段着色器以及后面的环节的主要工作是输出颜色与深度到帧缓存中,所以两个纹理在每个像素上的颜色 ...
- [转]解读Unity中的CG编写Shader系列6——不透明度与混合
1.不透明度当我们要将两个半透的纹理贴图到一个材质球上的时候就遇到混合的问题,由于前面的知识我们已经知道了片段着色器以及后面的环节的主要工作是输出颜色与深度到帧缓存中,所以两个纹理在每个像素上的颜色到 ...
随机推荐
- 【Unity】4.4 添加角色控制器
分类:Unity.C#.VS2015 创建日期:2016-04-10 一.简介 设计完毕基本的场景后,一般都需要先运行看看效果如何,即先让场景"动起来",以方便观察不同的位置,而不 ...
- /etc/ssh/sshd_config 关建字:PermitRootLogin no 禁示以root身份登录服务器
这种情况,不会影响,普通用户su到root
- 添加多个CCArmature
CCArmatureDataManager::sharedArmatureDataManager()-> addArmatureFileInfo("armature\\Cowboy0. ...
- CCardSlip
该类已经把tableview封装好,可以把它当做一个精灵来用,这样做的好处是,当一个界面同时需要多个tableview的时候就可以很好的解决这个问题,而且模块也更清晰. //------------- ...
- android笔记---ScrollView
<!--在创建xml文件的时候选择ScrollView类型--> <?xml version="1.0" encoding="utf-8"?& ...
- artificial%20intelligence%20a%20modern%20approach
http://stpk.cs.rtu.lv/sites/all/files/stpk/materiali/mi/artificial%20intelligence%20a%20modern%20app ...
- 【Windows】windows核心编程整理(下)
windows核心编程整理(上) windows核心编程整理(下) 线程的堆栈 每当创建一个线程时,系统就会为线程的堆栈(每个线程有他自己的堆栈)保留一个堆栈空间区域,并将一些物理存储器提交给这个以保 ...
- User-Defined-Literal自定义字面量
c++支持多种内置类型的字面量,比如: 123u // unsigned int 1.0 // double 1.6f // float 'a' // char 4ULL // unsigned lo ...
- 14款超时尚的HTML5时钟动画
时钟动画在网页应用中也非常广泛,在一些个人博客中,我们经常会看到一些相当个性化的HTML5时钟动画.今天我们向大家分享了14款形态各异的超时尚HTML5时钟动画,其中有圆盘时钟.3D时钟.个性化时钟等 ...
- idea 在tomcat中部署的时候 莫名其妙的错误
针对web项目需要 打成 war exploded 包,这样就不会每次重新构建打包,也不会出现莫名其妙的错误