弦抖动Shader

分享一个今天写的Shader,琴弦抖动。
可以振幅、频率、起始位置等。先上图:
在这里插入图片描述
使用这个Shader的模型顶点不能太好,我这里用的是Unity默认的3D物体,Panel。

好的,下面是原码:

Shader "Custom/VectorAnim" {
	Properties {
		//流动纹理
		_MainTex ("Main Tex", 2D) = "white" {}
		//影响颜色
		_Color("Color Tint",Color)=(1,1,1,1)
		//幅度
		_Magnitude("Distortion Magnitude" ,Float)=1
		//波动频率
		_Frequency("Distortion Frequency",Float)=1
		//波动起点
		_TextNum("TextNum",Float)=0.5
		//弧形跨度
		_TextNum2("TextNum2",Float)=0.5
	}
	SubShader {	
		//DisableBatching关闭批处理
			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"

				sampler2D _MainTex;
				float4 _MainTex_ST;
				float4 _Color;
				float _Magnitude;
				float _Frequency;
				float _TextNum;
				float _TextNum2;

				struct a2v{
					float4 vertex:POSITION;
					float4 texcoord:TEXCOORD0;
				};

				struct v2f{
					float4 pos:SV_POSITION;
					float uv:TEXCOORD0;
				};

				v2f vert(a2v v){
					v2f o;
					float4 offset= float4(0.0,0.0, 0.0, 0.0);
					//波动更具时间变化 乘以三个分量使的左形成错落感
					offset.y = sin(_Frequency * _Time.y) * _Magnitude * ( sin((v.vertex.x-_TextNum)*_TextNum2));
					o.pos = UnityObjectToClipPos(v.vertex + offset);
					
					o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
					o.uv +=  float2(0.0, _Time.y);

					return o;
				}

				fixed4 frag(v2f i):SV_Target{
					fixed4 c = tex2D(_MainTex, i.uv);
					c.rgb *= _Color.rgb;
					return c;
				}
				ENDCG
			}
	} 
	FallBack "off"//"Transparent/VertexLit"
}

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小盖子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值