unity-shader溶解效果--最高效的实现方案!!!!!!

最高效! 最高效!! 最高效!!!!的实现:从上到下逐渐消融的效果:
在这里插入图片描述在这里插入图片描述话不多说:上代码

Shader "Unlit/dissolve"
{
    Properties
    {
        _MainTex ("Texture", 2D) = "white" {}
        _DissolveTex ("DissolveTex", 2D) = "white" {}
        _DissolveY("Current Y of the dissolve effect",float) = 10
        _DissolveSize("Size of the effect",float) = 2
        _StartingY("Starting Point of the effect",float)=-10
    }
    SubShader
    {
        Tags { "RenderType"="Opaque" }
        LOD 100
        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;
                float3 worldPos : TEXCOORD1;
            };

            sampler2D _MainTex;
            float4 _MainTex_ST;
            sampler2D _DissolveTex;

            float _DissolveY;
            float _DissolveSize;
            float _StartingY;
            v2f vert (appdata v)
            {
                v2f o;
                o.vertex = UnityObjectToClipPos(v.vertex);
                o.uv = TRANSFORM_TEX(v.uv, _MainTex);
                o.worldPos = mul(unity_ObjectToWorld,v.vertex);
                return o;
            }
            fixed4 frag (v2f i) : SV_Target
            {
                float transition= _DissolveY - i.worldPos.y;
                clip(_StartingY + (transition + (tex2D(_DissolveTex,i.uv))* _DissolveSize));


                fixed4 col = tex2D(_MainTex, i.uv);
                
                return col;
            }
            ENDCG
        }
    }
}

这里特别说明一下:Clip函数:
(1)clip()函数可以丢弃掉一些不满足条件的像素
比如clip(xx.a-0.3)将丢弃掉alpha值小于0.3的像素。
等价于
if(xx.a<0.3)
discard;
(2)意思就是 clip(小于0的数):结果是会被全部丢弃
例如 clip(-1)会全部丢弃,clip(0)全部显示,不是必须使用clip(a-b)这种僵硬表达式。
在这里插入图片描述
(3)写了一个C#测试脚本,参数就是上图中的,自己动手+思考
就能深刻理解:

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

public class Dissolve : MonoBehaviour
{
    public Material dissolveMaterial;
    public float speed,min, startTime;
    private float currentY = 10;
    private void Update(){
        if(currentY > -30){
            dissolveMaterial.SetFloat("_DissolveY",currentY);
            currentY -= Time.deltaTime * speed;
            Debug.LogError("currentY="+currentY);
        }
        if (Input.GetKeyDown(KeyCode.E))
        {
            TriggerEffect();
        }
    }
    private void TriggerEffect(){
        currentY =5;
        startTime = Time.time;
    }
}

这几天有点懈怠了!!不要为自己找借口~~ i love you !!!

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
想要实现Unity中的角色消失、溶解、隐身效果,可以使用Shader实现。 其中,实现角色消失和溶解效果的关键是使用渐变效果,在角色表面进行透明度的渐变,使其看起来像是慢慢消失或溶解效果。 以下是一个简单的Shader代码示例,可以实现角色消失和溶解效果: ``` Shader "Custom/Dissolve" { Properties { _MainTex ("Texture", 2D) = "white" {} _DissolveAmount ("Dissolve Amount", Range(0.0, 1.0)) = 0.0 _DissolveColor ("Dissolve Color", Color) = (1,1,1,1) } SubShader { Tags { "Queue"="Transparent" "RenderType"="Transparent" } LOD 100 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 _MainTex; float _DissolveAmount; float4 _DissolveColor; v2f vert (appdata v) { v2f o; o.vertex = UnityObjectToClipPos(v.vertex); o.uv = v.uv; return o; } fixed4 frag (v2f i) : SV_Target { float4 col = tex2D(_MainTex, i.uv); col.a *= smoothstep(_DissolveAmount, _DissolveAmount + 0.1, col.r); col.rgb = lerp(col.rgb, _DissolveColor.rgb, col.a); return col; } ENDCG } } } ``` 使用该Shader时,需要在Material中设置_DissolveAmount参数的值来控制角色消失或溶解的程度,并且可以通过设置_DissolveColor参数来改变消失或溶解的颜色。 至于实现隐身效果,可以使用类似的渐变效果,但需要考虑到角色移动时的转换效果。具体实现方法可以根据需求进行调整。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值