Baste 发表于 2023-3-9 16:59

Unity Shader 实现UGUI下图片的倒影效果

效果图


实现原理很简单,首先创建两个Image一个作为原图另一个作为倒影图。倒影图跟原图旋转180度,然后呢让倒影图随着y坐标值修改透明值。这样感觉就出来了。
Shader代码:
Shader "Unlit/UIShadow"
{
    Properties
    {
       _MainTex("Sprite Texture", 2D) = "white" {}
      _Color("Tint", Color) = (1,1,1,1)
      _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
       _UseUIAlphaClip("Use Alpha Clip", Float) = 0

      _Pow("Pow",range(1,10)) = 1
    }

      SubShader
      {
            Tags
            {
                "Queue" = "Transparent"
                "IgnoreProjector" = "True"
                "RenderType" = "Transparent"
                "PreviewType" = "Plane"
                "CanUseSpriteAtlas" = "True"
            }

            Stencil
            {
                Ref
                Comp
                Pass
                ReadMask
                WriteMask
            }

            Cull Off
            Lighting Off
            ZWrite Off
            ZTest
            Blend SrcAlpha OneMinusSrcAlpha
            ColorMask

            Pass
            {
            CGPROGRAM
                #pragma vertex vert
                #pragma fragment frag
                #pragma target 2.0

                #include "UnityCG.cginc"
                #include "UnityUI.cginc"

                #pragma multi_compile __ UNITY_UI_CLIP_RECT
                #pragma multi_compile __ UNITY_UI_ALPHACLIP

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

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

                sampler2D _MainTex;
                fixed4 _Color;
                fixed4 _TextureSampleAdd;
                float4 _ClipRect;
                float4 _MainTex_ST;
                float _Pow;

                v2f vert(appdata_t v)
                {
                  v2f OUT;
                  UNITY_SETUP_INSTANCE_ID(v);
                  UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(OUT);
                  OUT.worldPosition = v.vertex;
                  OUT.vertex = UnityObjectToClipPos(OUT.worldPosition);

                  OUT.texcoord = TRANSFORM_TEX(v.texcoord, _MainTex);

                  OUT.color = v.color * _Color;
                  return OUT;
                }

                fixed4 frag(v2f IN) : SV_Target
                {
                  half4 color = (tex2D(_MainTex, IN.texcoord) + _TextureSampleAdd) * IN.color;

                  color.a *= pow(1 - IN.texcoord.y, _Pow);

                  #ifdef UNITY_UI_CLIP_RECT //这里是Mask裁剪用的
                  color.a *= UnityGet2DClipping(IN.worldPosition.xy, _ClipRect);
                  #endif

                  #ifdef UNITY_UI_ALPHACLIP
                  clip(color.a - 0.009);
                  #endif

                  return color;
                }
            ENDCG
            }
      }
}工程下载
页: [1]
查看完整版本: Unity Shader 实现UGUI下图片的倒影效果