水流动效果Shader

编程入门 行业动态 更新时间:2024-10-17 00:25:59

<a href=https://www.elefans.com/category/jswz/34/1690361.html style=水流动效果Shader"/>

水流动效果Shader

【效果图】

 

【实现步骤】

  1. 新建一个Shader,命名为WaterFlow,将下面的代码复制进去
  2. 新建一个材质,命名为WaterFlow,选择刚才创建的shader
  3. 给材质赋值下面的贴图

4.新建一个Plane,将刚才创建的材质赋值给这个平面

5.运行程序看效果,调节Magnitude,Frequency,Speed改效果

【shader代码详解】

Shader "Custom/WaterFlow"
{Properties{_MainTex("MainTex",2D) = "white"{}//存放贴图_Color("Color Tint",Color) = (1,1,1,1)//控制整体颜色_Magnitude("Magnitude",Float) = 0.1//控制波动频率_Frequency("Frequency",Float) = 0.5//控制波动幅度,参考正弦波的频率幅度来理解_Speed("Speed", Float) = 0.01//控制流动速度}SubShader{//指定透明度混合渲染队列、该Shader不受投影器影响、该Shader要使用透明度混合、顶点动画不能批处理Tags{"Queue" = "Transparent" "IgnoreProjector" = "True" "RenderType" = "Transparent" "DisableBatching" = "True"}Pass{//指定前向渲染模式Tags{"LightMode" = "ForwardBase"}ZWrite Off//关闭深度读写Blend SrcAlpha OneMinusSrcAlpha//开启混合模式Cull Off//关闭剔除功能CGPROGRAM#pragma vertex vert#pragma fragment frag#include "UnityCG.cginc"//定义Properties中的变量sampler2D _MainTex;float4 _MainTex_ST;//纹理的缩放和偏移值,TRANSFORM_TEX会调用fixed4 _Color;float _Magnitude;float _Frequency;float _Speed;struct a2v {float4 vertex:POSITION;float2 texcoord:TEXCOORD0;};struct v2f {float4 pos:SV_POSITION;float2 uv:TEXCOORD0;};v2f vert(a2v v) {v2f o;float4 offset = float4(0, 0, 0, 0);//顶点偏移offset.y = sin(_Frequency *_Time.y+ v.vertex.x+ v.vertex.y+ v.vertex.z)*_Magnitude;//顶线Y坐标随时间偏移o.pos = UnityObjectToClipPos(v.vertex + offset);//顶点从模型空间到裁剪空间o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);//传递UV坐标o.uv += float2(0, _Time.y*_Speed);//纹理动画,水平方向上的移动return o;}fixed4 frag(v2f i) :SV_Target{fixed4 c = tex2D(_MainTex,i.uv);//根据UV坐标进行纹理采样c.rgb *= _Color.rgb;return c;}ENDCG}}FallBack "Transparent/VertexLit"
}

【其他】

  • 可以修改顶点坐标和UV坐标实现合适的移动
  • 最好选择合适的贴图配合

【参考】

《shader入门精要》

更多推荐

水流动效果Shader

本文发布于:2024-02-13 02:36:11,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1690369.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:水流   效果   Shader

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!