当前位置:   article > 正文

Unity UI流光shader特效实现_unity ui shader

unity ui shader

原地址
在基础上调整了一下,拿来即用。

参数面板
在这里插入图片描述

效果
在这里插入图片描述

控制shader的代码。如果想做延时流光可以写个协程之类的。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;

public class ImageFlow : MonoBehaviour
{
	private float widthRate = 1;
	private float heightRate = 1;
	private float xOffsetRate = 0;
	private float yOffsetRate = 0;
	public Shader shader;
	public Color color = Color.yellow;
	public float power = 0.55f;
	public float speed = 5;
	public float largeWidth = 0.003f;
	public float littleWidth = 0.0003f;
	public float length = 0.1f;
	public float skewRadio = 0.2f;//倾斜
	public float moveTime = 0;
	float endMoveTime = 0;
	private MaskableGraphic maskableGraphic;
	Image image;
	Material imageMat = null;
	void Awake()
	{
		maskableGraphic = GetComponent<MaskableGraphic>();
		if (maskableGraphic)
		{
			image = maskableGraphic as Image;
			if (image)
			{
				imageMat = new Material(shader);
				widthRate = image.sprite.textureRect.width * 1.0f / image.sprite.texture.width;
				heightRate = image.sprite.textureRect.height * 1.0f / image.sprite.texture.height;
				xOffsetRate = (image.sprite.textureRect.xMin) * 1.0f / image.sprite.texture.width;
				yOffsetRate = (image.sprite.textureRect.yMin) * 1.0f / image.sprite.texture.height;

				image.material = imageMat;
			}
		}
	}
	
	void Start()
	{
		SetShader();
	}
	
	void Update()
	{
		moveTime = Time.time;

		//调试时开启,不用时注释掉
		SetShader();
	}
	public void SetShader()
	{
		skewRadio = Mathf.Clamp(skewRadio, 0, 1);
		length = Mathf.Clamp(length, 0, 0.5f);
		imageMat.SetColor("_FlowlightColor", color);
		imageMat.SetFloat("_Power", power);
		imageMat.SetFloat("_MoveSpeed", speed);
		imageMat.SetFloat("_LargeWidth", largeWidth);
		imageMat.SetFloat("_LittleWidth", littleWidth);
		imageMat.SetFloat("_SkewRadio", skewRadio);
		imageMat.SetFloat("_Lengthlitandlar", length);
		imageMat.SetFloat("_MoveTime", moveTime);

		imageMat.SetFloat("_WidthRate", widthRate);
		imageMat.SetFloat("_HeightRate", heightRate);
		imageMat.SetFloat("_XOffset", xOffsetRate);
		imageMat.SetFloat("_YOffset", yOffsetRate);
	}
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75

shader代码

Shader "Custom/UI/Flowlight" {
	Properties {
		[PerRendererData] _MainTex("Sprite Texture", 2D) = "white" {}
        _Color("Tint", Color) = (1, 1, 1, 1)
        [MaterialToggle] PixelSnap("Pixel snap", float) = 0

        /* Flowlight */
        _FlowlightColor("Flowlight Color", Color) = (1, 0, 0, 1)
        _Lengthlitandlar("LangthofLittle and Large", range(0,0.5)) = 0.005
        _MoveSpeed("MoveSpeed", float) = 5
        _Power("Power", float) = 1
        _LargeWidth("LargeWidth", range(0,0.005)) = 0.0035
        _LittleWidth("LittleWidth", range(0,0.001)) = 0.002
		_SkewRadio("SkewRadio", Range(0, 1)) = 0.2//倾斜度,0-1
		_MoveTime("MoveTime", float) = 0//控制扫光显示的位置,0-1
        /* --------- */

		_WidthRate("WidthRate",float) = 0
		_XOffset("XOffset",float) = 0
		_HeightRate("HeightRate",float) = 0
		_YOffset("YOffset",float) = 0

        /* UI */
        _StencilComp("Stencil Comparison", Float) = 8
        _Stencil("Stencil ID", Float) = 0
        _StencilOp("Stencil Operation", Float) = 0
        _StencilWriteMask("Stencil Write Mask", Float) = 255
        _StencilReadMask("Stencil Read Mask", Float) = 255
        _ColorMask("Color Mask", Float) = 15
        /* -- */
	}
	SubShader {
		Tags { 
			"Queue" = "Transparent"
			"IgnoreProjector" = "True"
			"RenderType" = "Transparent"
			"PreviewType" = "Plane"
			"CanUseSpriteAtlas" = "True"
		}
		Cull Off
        Lighting Off
        ZWrite Off
        Blend One OneMinusSrcAlpha
        ColorMask[_ColorMask]

		/* UI */
        Stencil{
            Ref[_Stencil]
            Comp[_StencilComp]
            Pass[_StencilOp]
            ReadMask[_StencilReadMask]
            WriteMask[_StencilWriteMask]
        }
        /* -- */

		Pass {
			CGPROGRAM
			#pragma vertex vert
			#pragma fragment frag
			#pragma multi_compile _ PIXELSNAP_ON
			#include "UnityCG.cginc"

        	struct appdata_t {
				float4 vertex : POSITION;
				float4 color : COLOR;
				float2 texcoord : TEXCOORD0;
    		};

			struct v2f {
				float4 vertex : SV_POSITION;
				fixed4 color : COLOR;
				half2 texcoord : TEXCOORD0;
				float4 worldPosition: TEXCOORD1;
			};

			fixed4 _Color;
			/* Flowlight */
			float _Power;
			float _LargeWidth;
			float _LittleWidth;
			float _Lengthlitandlar;
			float _MoveSpeed;
			float _SkewRadio;
			float _MoveTime;
			fixed4 _FlowlightColor;
			/* --------- */
			float _UVPosX;
			v2f vert(appdata_t IN) {
				v2f OUT;
				OUT.worldPosition = IN.vertex;
				OUT.vertex = UnityObjectToClipPos(IN.vertex);
				OUT.texcoord = IN.texcoord;
				OUT.color = IN.color * _Color;

				#ifdef PIXELSNAP_ON
				OUT.vertex = UnityPixelSnap(OUT.vertex);
				#endif

				return OUT;
			}

			sampler2D _MainTex;
			float4 _MainTex_ST;
			float _WidthRate;
			float _XOffset;
			float _HeightRate;
			float _YOffset;

			bool _UseClipRect;
			float4 _ClipRect;
			float _ClipSoftX;
			float _ClipSoftY;
    		fixed4 frag(v2f IN) : SV_Target {
        		fixed4 c = tex2D(_MainTex, IN.texcoord);
				//这里加了个判断,是否有半透明。当然可以根据自己的需要,通过半透明度去计算最终的结果达到目的
				if (c.a == 1){
					/*使用裁剪*/
					if (_UseClipRect)
					{
						float2 factor = float2(0.0, 0.0);
						float2 tempXY = (IN.worldPosition.xy - _ClipRect.xy) / float2(_ClipSoftX, _ClipSoftY)*step(_ClipRect.xy, IN.worldPosition.xy);
						factor = max(factor, tempXY);
						float2 tempZW = (_ClipRect.zw - IN.worldPosition.xy) / float2(_ClipSoftX, _ClipSoftY)*step(IN.worldPosition.xy, _ClipRect.zw);
						factor = min(factor, tempZW);
						c.a *= clamp(min(factor.x, factor.y), 0.0, 1.0);
					}
					/* --------- */
				
					/* Flowlight */
					//计算流动的标准uvX从-0.5到1.5范围
					_UVPosX = _XOffset + (fmod(_MoveTime*_MoveSpeed, 1) * 2 - 0.5)* _WidthRate;
					//标准uvX倾斜
					_UVPosX += (IN.texcoord.y - _HeightRate*0.5- _YOffset)*_SkewRadio;
					//以下是计算流光在区域内的强度,根据到标准点的距离的来确定强度,为了使变化更柔和非线性,使用距离平方或者sin函数也可以
					float lar = pow(1 - _LargeWidth*_WidthRate, 2);
					float lit = pow(1 - _LittleWidth*_WidthRate, 2);
					//第一道流光,可以累加任意条,如下
					fixed4 cadd = _FlowlightColor* saturate((1 - saturate(pow(_UVPosX - IN.texcoord.x,2))) - lar)*_Power /(1-lar);
					cadd += _FlowlightColor* saturate((1 - saturate(pow(_UVPosX - _Lengthlitandlar*_WidthRate - IN.texcoord.x, 2))) - lit)*_Power/ (1-lit);
					
					cadd.rgb *= cadd.a;
					
					c.rgb += cadd.rgb;
					/* --------- */
				}
				c.rgb *= c.a;
        		return c;
    		}
        	ENDCG
    	}
	}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/109495
推荐阅读
相关标签
  

闽ICP备14008679号