shader之——溶解

描述

  在网上看到很多溶解的例子 ,有个点不太好理解,就是溶解的边缘加上颜色过度,可以控制过度的宽度以及颜色值,

今天来研究一下这个算法

代码如下:

Shader "Unlit/NewUnlitShader"
{
    Properties
    {
        _MainTex ("Texture", 2D) = "white" {}
        _ClipTex ("ClipTex",2D ) = "white" {}
        _scal ("Scal",Range(0,1)) = 0.5
        _cut ("cut",Range(0,1)) =0.01
        _scalColor("scalColor",color) = (1,1,1,1)
    }
    SubShader
    {
        Tags { "RenderType"="Opaque" }
        LOD 100

        Pass
        {
            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag
            #pragma multi_compile_fog
            
            #include "UnityCG.cginc"

            struct appdata
            {
                float4 vertex : POSITION;
                float2 uv : TEXCOORD0;
                float3 normal:NORMAL;
            };

            struct v2f
            {
                float2 uv : TEXCOORD0;
                UNITY_FOG_COORDS(1)
                float4 pos : SV_POSITION;
                float4 vertex :TEXCOORD2; 
                float3 normal :TEXCOORD3;
                 
            };

            sampler2D _MainTex;
            float4 _MainTex_ST;
            sampler2D _ClipTex;
            float _scal;
            float _cut;
            float4 _scalColor;
            
            v2f vert (appdata v)
            {
                v2f o;
                o.pos = UnityObjectToClipPos(v.vertex);
                o.uv = TRANSFORM_TEX(v.uv, _MainTex);
                o.vertex =normalize(v.vertex) ;
                o.normal =normalize(v.normal);
                UNITY_TRANSFER_FOG(o,o.vertex);
                return o;
            }
            
            fixed4 frag (v2f i) : SV_Target
            {
                fixed4 col = tex2D(_MainTex, i.uv);
                
                fixed4 clipTex = tex2D (_ClipTex,i.vertex.zy + float2(0.5,0.5));

                
                
                // 切割的边缘 想要加一种颜色,这个颜色需要跟原有颜色去过度
                //这里的lerp第三个值是个难点
                //根据a b,把它转换成0到1  a与b为clipTex.r的最大值与最小值 他们的差值也就是这个颜色的宽度
                //思路是 将这个clipTex.r * x - y 让他变成0到1
                //那么a 跟b 通过这个算法正好 = 0——1
                // a * x -y = 0
                // b * x -y = 1
                //得出 (b - a)* x = 1
                // x = 1/(b - a)
                // y = b*x-1= b/(b-a)-1
                
                float a = _cut;  //切割的alpha值
                float b = _cut +_scal; //加上他的宽度,就是过度颜色的另外一段的alpha值
                float x = 1/(b - a);
                float y =  b/(b-a)-1;

                if (clipTex.r > a && clipTex.r < b){   //当这个值大于切割的alpha 小于颜色的宽度值,给他一个颜色,并且按照alpha值大小去混合
                col =lerp( _scalColor ,col, clipTex.r * x-y);
                } 
                
                //如果小于我们指定的alpha值 ,将模型切割
                if (clipTex.r < a){
                    clip(-1.0);
                }

                UNITY_APPLY_FOG(i.fogCoord, col);
                return col ;
            }
            ENDCG
        }
    }
}


//如果需要加两个颜色去过度的话,那么先算出第两个宽度+在一起的颜色 lerp过后,再算最边缘的宽度颜色,
//用同样的方法进行lerp,只需要找出相对应的a 与b(也就是颜色宽度的最小alpha值与最大alpha值)

主要的算法已经注释的很清楚了 ,应该很容易理解了,网上的好多算法都是错的,会发现过度地方的颜色根本不受自己控制,所以特别写了这篇

希望对大家有所帮助



  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Unity Shader Graph是Unity引擎中的一种可视化编程工具,它可以用于创建自定义的着色器效果。溶解特效是一种常见的特效,在游戏和动画中经常使用。 要使用Unity Shader Graph实现溶解特效,我们需要做以下几个步骤: 1. 创建Shader Graph:打开Unity编辑器,创建一个新的Shader Graph。可以通过右键点击Assets面板中的空白区域,选择Create->Shader->PBR Graph来创建一个新的Shader Graph。 2. 添加输入节点:在Shader Graph编辑器中,我们需要添加溶解特效所需的输入节点。这些节点可能包括Texture2D用于溶解图案、Float用于控制溶解的进度等。 3. 控制溶解过程:在Shader Graph中,我们可以使用节点连接和编辑来控制溶解特效的过程。例如,我们可以使用Lerp节点将溶解图案与原始纹理进行混合,实现溶解的效果。 4. 添加溶解动画:通过使用Time节点,我们可以在Shader Graph中添加时间变量,以使溶解过程可以动态进行,从而实现溶解特效的动画效果。通过控制Time节点的输入值,我们可以控制溶解特效的速度、方向等。 5. 调整其他属性:除了溶解图案和动画外,还可以通过Shader Graph调整其他属性,如颜色、透明度、光照等,以使溶解特效具有更多的变化和个性化。 6. 导入及应用Shader:将编写好的Shader Graph保存,然后将其导入Unity项目中。之后,我们可以将其应用到需要溶解特效的材质上,以实现溶解特效效果。 总之,通过使用Unity Shader Graph,我们可以通过可视化编辑界面来快速创建和调整溶解特效。这种方法非常直观和灵活,使得艺术家和开发人员可以快速实现他们想要的效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值