Unity3D编辑器扩展Unity3D中实现UI界面控制,UI界面的显示和隐藏实现

Posted 恬静的小魔龙

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Unity3D编辑器扩展Unity3D中实现UI界面控制,UI界面的显示和隐藏实现相关的知识,希望对你有一定的参考价值。

推荐阅读

大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有用记得一键三连哦。

一、前言

在开发中,可能遇到管理很多的UI界面,但是需要切换UI界面的情况。

这种情况下,通常就是在Hierarchy视图中勾选需要显示的UI界面,关闭不需要显示的UI界面

这种操作很麻烦,所以就写了一个直接在脚本组件中控制UI界面的功能,可以直接切换UI界面,提升效率。

先来看一下效果图:

二、实现

(1)先搭建UI界面,做两个UI界面进行切换:

(2)新建ChangeModule.cs脚本,双击修改脚本:

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

[System.Serializable]
public class ChangeModule

    [SerializeField] private string m_Name;
    [SerializeField] private bool m_Selected;
    [SerializeField] private GameObject m_Panel;

    public string name  get  return m_Name;  set  m_Name = value;  
    public bool select  get  return m_Selected;  set  m_Selected = value;  
    public GameObject panel  get  return m_Panel;  set  m_Panel = value;  

这个脚本主要是对每个UI界面控制的对象的属性设置。

(3)新建ChangePanel.cs脚本,双击修改脚本:

using System.Collections.Generic;
using UnityEngine;
using UnityEngine.EventSystems;
using UnityEngine.UI;
using XCharts;

[DisallowMultipleComponent]
[ExecuteInEditMode]
public class ChangePanel : MonoBehaviour

    [SerializeField] private List<ChangeModule> m_ChangeModule = new List<ChangeModule>();

    void Awake()
    
        InitModuleButton();
    

    void Update()
    
#if UNITY_EDITOR
        InitModuleButton();
#endif
    

    void InitModuleButton()
    
        for (int i = 0; i < m_ChangeModule.Count; i++)
        
            var module = m_ChangeModule[i];
            if (module.select)
            
                module.panel.SetActive(true);
                module.select = true;
            
            else
            
                module.panel.SetActive(false);
                module.select = false;
                
        
    

这个脚本就是为了控制UI界面的。

(4)将ChangePanel.cs脚本组件添加到任意对象,现在就可以在不运行的状态下控制UI界面了:

(5)在上一步其实就已经完成了功能,但是我还想将这个再优化一下,所以就新建一个Editor文件夹,在Editor文件夹里面新建ChangeModuleDrawer.cs脚本,双击修改脚本:

using UnityEditor;
using UnityEngine;

[CustomPropertyDrawer(typeof(ChangeModule), true)]
public class ChangeModuleDrawer : PropertyDrawer

    public override void OnGUI(Rect pos, SerializedProperty prop, GUIContent label)
    
        Rect drawRect = pos;
        drawRect.height = EditorGUIUtility.singleLineHeight;
        SerializedProperty m_Name = prop.FindPropertyRelative("m_Name");
        SerializedProperty m_Selected = prop.FindPropertyRelative("m_Selected");
        SerializedProperty m_Panel = prop.FindPropertyRelative("m_Panel");
        drawRect.width = 30;
        EditorGUI.PropertyField(drawRect, m_Selected, GUIContent.none);
        drawRect.x += 30;
        drawRect.width = 100;
        EditorGUI.PropertyField(drawRect, m_Name, GUIContent.none);
        drawRect.x += 120;
        drawRect.width = 200;
        EditorGUI.PropertyField(drawRect, m_Panel, GUIContent.none);
    

    public override float GetPropertyHeight(SerializedProperty prop, GUIContent label)
    
        return 1 * EditorGUIUtility.singleLineHeight + 1 * EditorGUIUtility.standardVerticalSpacing;
    

效果图:

现在感觉方便多了。

三、后记

本篇文章实现了Unity3D的拓展开发,可以快速的切换UI界面,适用于UI界面比较多的情况。


你的点赞就是对博主的支持,有问题记得留言:

博主主页有联系方式。

博主还有跟多宝藏文章等待你的发掘哦:

专栏方向简介
Unity3D开发小游戏小游戏开发教程分享一些使用Unity3D引擎开发的小游戏,分享一些制作小游戏的教程。
Unity3D从入门到进阶入门从自学Unity中获取灵感,总结从零开始学习Unity的路线,有C#和Unity的知识。
Unity3D之UGUIUGUIUnity的UI系统UGUI全解析,从UGUI的基础控件开始讲起,然后将UGUI的原理,UGUI的使用全面教学。
Unity3D之读取数据文件读取使用Unity3D读取txt文档、json文档、xml文档、csv文档、Excel文档。
Unity3D之数据集合数据集合数组集合:数组、List、字典、堆栈、链表等数据集合知识分享。
Unity3D之VR/AR(虚拟仿真)开发虚拟仿真总结博主工作常见的虚拟仿真需求进行案例讲解。
Unity3D之插件插件主要分享在Unity开发中用到的一些插件使用方法,插件介绍等
Unity3D之日常开发日常记录主要是博主日常开发中用到的,用到的方法技巧,开发思路,代码分享等
Unity3D之日常BUG日常记录记录在使用Unity3D编辑器开发项目过程中,遇到的BUG和坑,让后来人可以有些参考。

以上是关于Unity3D编辑器扩展Unity3D中实现UI界面控制,UI界面的显示和隐藏实现的主要内容,如果未能解决你的问题,请参考以下文章

Unity3D编辑器扩展Unity3D中实现Text的字体的替换

Unity3D编辑器扩展Unity3D中实现Text的字体的替换

虚拟仿真Unity3D中实现UI跟随3D模型旋转移动UI一直面朝屏幕

虚拟仿真Unity3D中实现UI跟随3D模型旋转移动UI一直面朝屏幕

如何在Unity3d开发中实现文字的渐隐效果

Unity3D 在自定义脚本中实现Button组件上的OnClick面板