【Unity之IMGUI】—编译模式下控件可视化及其封装

在这里插入图片描述


‍个人主页:@元宇宙-秩沅

‍ hallo 欢迎 点赞 收藏⭐ 留言 加关注✅!

本文由 秩沅 原创

‍ 收录于专栏:UnityUI篇实战

️IMGUI封装实践【二】



文章目录

    • ️IMGUI封装实践【二】
    • 前言
    • (==A==) 封装可视化脚本控制基类
    • (==B==) 控件创建及其封装——按钮
    • (==C==) 开始创建预制体包


前言

在这里插入图片描述

缺点1:无法在编译过程进行可视化调整
缺点2:无法分辨率自适应

在这里插入图片描述


A 封装可视化脚本控制基类


此图可忽略

【Unity之IMGUI】—编译模式下控件可视化及其封装_第1张图片

  • UML类图
    【Unity之IMGUI】—编译模式下控件可视化及其封装_第2张图片

  • 性能优化代码
    【Unity之IMGUI】—编译模式下控件可视化及其封装_第3张图片

  • 完整代码:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
//-------------------------------------
//—————————————————————————————————————
//___________项目:       ______________
//___________功能: 让所有组件都可视化编辑
//___________创建者:秩沅_______________
//_____________________________________
//-------------------------------------

[ExecuteAlways] //关键特性
public class ShowAllContorlRoot : MonoBehaviour
{
    private ControlFather[] allContorls; //里氏替换原则,装所有子类

    private void Start()
    {
        allContorls = this.GetComponentsInChildren<ControlFather>();
    }
    private void OnGUI()
    {
        foreach (ControlFather  item in allContorls)
        {
            //1.表示没有运行时(编译时)也来获取,Start是点击运行时可以获取
            //2.避免了运行时重复执行该API。消耗性能
            if( !Application.isPlayer)
            {
                allContorls = this.GetComponentsInChildren<ControlFather>();
            }
            item.Judge();
        }
    }
}


B 控件创建及其封装——按钮


【Unity之IMGUI】—编译模式下控件可视化及其封装_第4张图片
【Unity之IMGUI】—编译模式下控件可视化及其封装_第5张图片

  • 按钮封装代码
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Events;
//-------------------------------------
//—————————————————————————————————————
//___________项目:       ______________
//___________功能: 创建按钮
//___________创建者:秩沅_______________
//_____________________________________
//-------------------------------------
public class Button : ControlFather
{
    public event  UnityAction triggerEvent; 
                                            //事件的添加在此起到妙用
                                            //只要在外部给予响应函数                

    protected override void OffDrawStyle()
    {
        if(GUI.Button(ContorlPosition.LastPos ,ContorlContent))
        {
            triggerEvent?.Invoke();
        }
    }

    protected override void OnDrawstyle()
    {
       if(GUI.Button(ContorlPosition.LastPos, ContorlContent,ContorlStyle ) )
        {
           triggerEvent?.Invoke();
        }
    }
}


C 开始创建预制体包


【Unity之IMGUI】—编译模式下控件可视化及其封装_第6张图片

  • 目的: 便于套用


⭐【Unityc#专题篇】之c#进阶篇】

⭐【Unityc#专题篇】之c#核心篇】

⭐【Unityc#专题篇】之c#基础篇】

⭐【Unity-c#专题篇】之c#入门篇】

【Unityc#专题篇】—进阶章题单实践练习

⭐【Unityc#专题篇】—基础章题单实践练习

【Unityc#专题篇】—核心章题单实践练习


你们的点赞 收藏⭐ 留言 关注✅是我持续创作,输出优质内容的最大动力!


在这里插入图片描述


你可能感兴趣的:(#,UnityGUI篇,unity,游戏引擎)