Unity中使用C#脚本控制物体Material的透明度

实现方法

工程中遇到了这样的问题,需要进行调整物体的透明度。
通过查找资料发现,需要将Object的Rendering Mode调整为Fade才可以进行透明度a的调整。

因此,调整物体的透明度分为两步骤:

修改Rendering Mode
修改material的color属性

将物体调成实体也是同样的操作

代码如下,夹带了一些VRTK的手柄监视,就不删去了。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Events;
using VRTK;
using UnityEngine.Animations;

public class Car_boom : MonoBehaviour
{
    public GameObject carboom;
    public GameObject driver;
    public VRTK_ControllerEvents controllerEvents;
    public bool judge = false;

    public enum RenderingMode
    {
        Opaque,
        Cutout,
        Fade,
        Transparent,
    }
 
    public static void SetMaterialRenderingMode(Material material, RenderingMode renderingMode)
    {
        switch (renderingMode)
        {
            case RenderingMode.Opaque:
                material.SetInt("_SrcBlend", (int)UnityEngine.Rendering.BlendMode.One);
                material.SetInt("_DstBlend", (int)UnityEngine.Rendering.BlendMode.Zero);
                material.SetInt("_ZWrite", 1);
                material.DisableKeyword("_ALPHATEST_ON");
                material.DisableKeyword("_ALPHABLEND_ON");
                material.DisableKeyword("_ALPHAPREMULTIPLY_ON");
                material.renderQueue = -1;
                break;
            case RenderingMode.Cutout:
                material.SetInt("_SrcBlend", (int)UnityEngine.Rendering.BlendMode.One);
                material.SetInt("_DstBlend", (int)UnityEngine.Rendering.BlendMode.Zero);
                material.SetInt("_ZWrite", 1);
                material.EnableKeyword("_ALPHATEST_ON");
                material.DisableKeyword("_ALPHABLEND_ON");
                material.DisableKeyword("_ALPHAPREMULTIPLY_ON");
                material.renderQueue = 2450;
                break;
            case RenderingMode.Fade:
                material.SetInt("_SrcBlend", (int)UnityEngine.Rendering.BlendMode.SrcAlpha);
                material.SetInt("_DstBlend", (int)UnityEngine.Rendering.BlendMode.OneMinusSrcAlpha);
                material.SetInt("_ZWrite", 0);
                material.DisableKeyword("_ALPHATEST_ON");
                material.EnableKeyword("_ALPHABLEND_ON");
                material.DisableKeyword("_ALPHAPREMULTIPLY_ON");
                material.renderQueue = 3000;
                break;
            case RenderingMode.Transparent:
                material.SetInt("_SrcBlend", (int)UnityEngine.Rendering.BlendMode.One);
                material.SetInt("_DstBlend", (int)UnityEngine.Rendering.BlendMode.OneMinusSrcAlpha);
                material.SetInt("_ZWrite", 0);
                material.DisableKeyword("_ALPHATEST_ON");
                material.DisableKeyword("_ALPHABLEND_ON");
                material.EnableKeyword("_ALPHAPREMULTIPLY_ON");
                material.renderQueue = 3000;
                break;
        }
    }    

    // Start is called before the first frame update
    void Start()
    {
        driver = GameObject.Find("Gengon001");
        controllerEvents = GetComponent<VRTK_ControllerEvents>();
        //Setup controller event listeners
        GetComponent<VRTK_ControllerEvents>().StartMenuPressed += new ControllerInteractionEventHandler(DoStartMenuPressed);
    }

    // Update is called once per frame
    void Update()
    {
        
    }

    private void DoStartMenuPressed(object sender, ControllerInteractionEventArgs e)
    {
        if(!judge)//透明
        {
            //透明与renderingmode
            SetMaterialRenderingMode(driver.GetComponent<MeshRenderer>().material,RenderingMode.Fade);
            Color cr = driver.GetComponent<MeshRenderer>().material.color;
            cr.a = 100f/255f;
            driver.GetComponent<MeshRenderer>().material.color = cr;

            judge = true;
        }
        else//实体
        {
            //透明与renderingmode
            SetMaterialRenderingMode(driver.GetComponent<MeshRenderer>().material,RenderingMode.Opaque);
            Color cr = driver.GetComponent<MeshRenderer>().material.color;
            cr.a = 255f/255f;
            driver.GetComponent<MeshRenderer>().material.color = cr;

            judge = false;
        }
        
    }


    
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Unity相机控制是指在Unity游戏引擎,对游戏场景的摄像机进行控制和设置的功能。相机控制可以通过编写C#脚本来实现。 在Unity,通过C#编写脚本可以实现对相机的位置、旋转和缩放等属性的控制。可以使用Transform组件的方法来实现这些控制,例如使用Translate方法来移动相机的位置,使用Rotate方法来旋转相机的角度,使用Scale方法来缩放相机的大小。 除了基本的位置、旋转和缩放控制Unity还提供了其他功能丰富的相机控制选项。例如,可以设置相机的投影方式,可以使用透视投影或正交投影来呈现不同的视觉效果。可以设置相机的裁剪面,通过设置近裁剪面和远裁剪面的距离,控制场景的可见范围。 Unity还提供了一些相机运动效果的预设,例如平滑跟随目标物体、旋转围绕目标物体、观察目标物体等。通过调用相应的函数或方法,可以实现这些相机运动效果。 除了基本的相机控制Unity还支持对多个相机进行设置和管理。可以通过设置相机的渲染顺序,实现多个相机在场景的渲染效果。还可以通过在场景放置不同的视角相机,实现多角度观察场景。 总结来说,通过使用C#脚本编写代码,可以实现在Unity对相机的位置、旋转、缩放等属性进行控制,还可以实现一些相机运动效果和多相机管理等功能。这样可以为游戏场景创造出更多丰富和独特的视觉效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值