Shader实战(2):在unity中实现物体材质随时间插值渐变

目录

前言

一、shader代码

二、材质准备

三、控制代码


前言

最近想做一个物体两套材质随时间插值渐变的效果,本以为可以通过unity自带的Material.Lerp()实现,后来发现这个方法只适用于纯色的情况,其实与Color.Lerp()是同样的效果,后研究发现这个效果需要通过自定义shader来实现,因此记录如下

一、shader代码

新建一个shader名为TextureBlendShader

复制代码
Shader "Custom/TextureBlendShader"
{
    Properties
    {
        _StartTex ("Texture 1", 2D) = "white" {}
        _TargetTex ("Texture 2", 2D) = "white" {}
        _BlendAmount ("Blend Amount", Range(0, 1)) = 0
    }
    SubShader
    {
        Tags { "RenderType"="Opaque" }
        LOD 100

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

            struct appdata_t
            {
                float4 vertex : POSITION;
                float2 uv : TEXCOORD0;
                float2 uv1 : TEXCOORD1;
            };

            struct v2f
            {
                float2 uv : TEXCOORD0;
                float2 uv1 : TEXCOORD1;
                float4 vertex : SV_POSITION;
            };

            sampler2D _StartTex;
            sampler2D _TargetTex;
            float _BlendAmount;

            v2f vert (appdata_t v)
            {
                v2f o;
                o.vertex = UnityObjectToClipPos(v.vertex);
                o.uv = v.uv;
                o.uv1 = v.uv1;
                return o;
            }

            half4 frag (v2f i) : SV_Target
            {
                // 在这里使用 lerp 函数对两个贴图进行插值
                half4 col1 = tex2D(_StartTex, i.uv1);
                half4 col2 = tex2D(_TargetTex, i.uv1);
                half4 finalColor = lerp(col1, col2, _BlendAmount);
                return finalColor;
            }
            ENDCG
        }
    }
}

二、材质准备

首先有两套渲染好的材质

新建材质,使用上一步自定义的shader,然后将对应的贴图附上去

三、控制代码

新建一个脚本名为TextureBlendController.cs

cs 复制代码
using UnityEngine;

public class TextureBlendController : MonoBehaviour {
    public Material materialWithShader; // 包含自定义Shader的材质
    public Texture targetTexture; // 目标贴图
    public float transitionSpeed = 1.0f; // 渐变速度

    private Material currentMaterial; // 当前材质
    private float blendAmount = 0.0f; // 渐变值

    void Start() {
        currentMaterial = GetComponent<Renderer>().material;
    }

    void Update() {
        // 在指定速度下进行渐变
        blendAmount += Time.deltaTime * transitionSpeed;
        blendAmount = Mathf.Clamp01(blendAmount); // 将值限制在0到1之间

        // 更新Shader中的 BlendAmount 变量
        currentMaterial.SetFloat("_BlendAmount", blendAmount);

        // 渐变完成后停止
        if (blendAmount >= 1.0f) {
            enabled = false; // 可以根据需求停止更新
        }
    }
}

将这个脚本挂到所有需要渐变的物体上,通过改变blendAmount可以控制前后两套材质的混合程度。

效果如下

相关推荐
winlife_4 小时前
Unity 域重载会清空一切:Editor 工具如何让状态在重载后续命
unity·游戏引擎
深度森林6 小时前
无人机“路径规划”高价值专利案例:基于抗干扰粒子群优化的无人机路径规划方法
游戏引擎·cocos2d
小贺儿开发7 小时前
Unity3D 串口通信上位机联调系统
unity·串口·协议·数据·通信·传输·互动
tedcloud1238 小时前
ppt-master部署教程:快速搭建智能演示文稿系统
服务器·人工智能·系统架构·游戏引擎·powerpoint
SCLchuck13 小时前
UE5 地形材质UV
ue5·材质·uv
垂葛酒肝汤1 天前
Unity的UI扫光效果Shader
ui·unity·游戏引擎
mxwin1 天前
Unity Shader Alpha测试 · 模板测试 · 深度测试
unity·游戏引擎
UTwelve1 天前
【UE】材质与半透明 - 01. 基于Masked遮罩的抖动半透明 DitherMask
ue5·材质·虚幻引擎·着色器
2601_956002811 天前
冬日狂想曲(赠去马赛克补丁)2026.5.13最新版免费下载 转存后自动更新 (看到请立即转存 资源随时失效)pc手机版通用
智能手机·游戏引擎·电脑·游戏程序·动画·游戏美术
草木深雨纷纷1 天前
我的世界基岩版手机版(光影材质包大全)下载国际服集合下载分享
游戏·智能手机·游戏程序·材质