热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Unity——外挂编辑器

特殊目录Plugins:需要跨语言调用的代码逻辑代码储存目录,手机SDK接入Resource:储存跟随游戏包的资源目录Streaming

特殊目录                

        Plugins:需要跨语言调用的代码逻辑代码储存目录,手机SDK接入

        Resource:储存跟随游戏包的资源目录

StreamingAssets:只读,存储跟游戏包的资源目录

编辑目录:Editor

制作多目录合并

项目中建立的Editor目录,编辑器相关的逻辑和资源会放在其内部,相关内容,

在打包生成时,不会一起生成到项目中,玩家也不会使用到编辑器相关的内容。


//隐藏公共成员变量,同时保证脚本中变量的可访问度

[HideInInspector]

//私有变量,检视面板可见

[SerializeField]

//对象如果不标记为可序列化,则Unity在存储的时候,会认为他不可被序列化,那么也就无法被显示

[Serializable]

//给数值设定范围

[Range(int,int)]

//添加变量悬浮提示文字

[Tooltip(string)]

//当前成员变量上方加入一个标题文字

[Header(string)]

//指定输入框,拥有int行数据

[Multiline(int)]

//默认显示min行,最多显示max行内容,再多用滚动条控制显示区域

[TextArea(min,max)]

//小齿轮增加一个回调函数

[ContextMenu(string)] 

//第一个参数是菜单名称,第二个参数是右键点击的回调函数

[ContextMenuItem(name,funntion)]

//当前组件依赖于盒子碰撞器,当前组件挂载再对象上时,盒子碰撞体会一起被添加上,当该脚本没有被移除时,盒子碰撞体不能被移除

[RequireComponent(typeof(BoxCollider))]

//使生命周期函数,在编辑状态下可以运行,游戏中也可以正常使用

[ExecuteInEditMode]

//将Player组件添加到AddComponent上,第一个参数:分组名/组件名,第二个参数:列表中显示的顺序

[AddComponentMenu("自定义文件夹/自定义脚本",1)]


检视器高级修改(外挂式编程)

        项目中建立Editor目录

        

         Editor目录下建立外挂式开发脚本

         

        将编辑器脚本,与原始脚本进行关联

外挂脚本的方法

        1.引入编辑器的命名空间,检视器属于编辑器开发范畴

        

         2.继承Editor类,使用编辑器相关的成员变量和生命周期函数

        

         3.将编辑器开发脚本与需要编辑的组件脚本建立外挂关联关系

        

         4.需要在当前的外挂脚本中,获得需要被扩展的Player组件对象

        

         5.获取Player组件对象

        

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEditor;[CustomEditor(typeof(Player))]
//外挂的脚本因为存储在Editor目录下,所以不会被打入最终的游戏包
//不继承自Mono,而是继承自Editor
public class PlayerEditor : Editor
{//获得到需要编辑显示的组件private Player _Component;//当关联组件所在对象被添加或选中时调用private void OnEnable(){_CompOnent= target as Player;}//当关联组件所在对象被删除或取消时调用private void OnDisable(){_CompOnent= null;}
}

private void OnEnable()

当关联组件所在对象被选中或组件被添加时,调用

    当关联组件所在对象被取消或组件被移除时,调用
    private void OnDisable()

    

    //用于绘制检视面板的生命周期函数
    public override void OnInspectorGUI()

    

         //标题显示
        EditorGUILayout.LabelField("人物相关属性");

                

            

             将玩家的ID展示出来

         _Component.ID = EditorGUILayout.IntField("玩家ID", _Component.ID);

        

 对象数据类型绘制
       参数1:标题
       参数2:原始组件的值
       参数3:成员变量的类型
       参数4:是否可以将场景中的对象拖给这个成员变量
        _Component.Weapon = EditorGUILayout.ObjectField("持有武器", _Component.Weapon, typeof(GameObject), true) as GameObject;

        

   单选枚举(标题, 组件上的原始值)
        _Component.Pro = (PlayerProfression)EditorGUILayout.EnumPopup("玩家职业", _Component.Pro);

        

   多选枚举(标题, 组件上的原始值)
        _Component.LoveColor = (PlayerLoveColor)EditorGUILayout.EnumFlagsField("玩家喜欢的颜色", _Component.LoveColor);

        

 终极数据类型绘制
         更新可序列化数据
        serializedObject.Update();
         通过成员变量名找到组件上的成员变量
        SerializedProperty sp = serializedObject.FindProperty("Items");
         可序列化数据绘制(取到的数据,标题,是否将所有获得的序列化数据显示出来)
        EditorGUILayout.PropertyField(sp, new GUIContent("道具信息"), true);
         将修改的数据,写入到可序列化的原始数据中
        serializedObject.ApplyModifiedProperties();

        

   滑动条绘制
         滑动条显示(1.标题,2.原始变量,最小值,最大值)
        _Component.Atk = EditorGUILayout.Slider(new GUIContent("玩家攻击力"), _Component.Atk, 0, 100);

        if (_Component.Atk > 80)
        {
             显示消息框(红色)
            EditorGUILayout.HelpBox("攻击力太高了", MessageType.Error);
        }

        if (_Component.Atk <20)
        {
             显示消息框(黄色)
            EditorGUILayout.HelpBox("攻击力太低了", MessageType.Warning);
        }

        

        

按钮显示和元素排列
      (按钮是否被按下)显示按钮(按钮名称)
        GUILayout.Button("来个按钮");
        GUILayout.Button("来个按钮");

        if (GUILayout.Button("测试点击"))
        {
            Debug.Log("测试点击");
        }

        开始横向排列绘制
        EditorGUILayout.BeginHorizontal();

        GUILayout.Button("再来个按钮");
        GUILayout.Button("再来个按钮");

        结束横向排列绘制
        EditorGUILayout.EndHorizontal();

        

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEditor;[CustomEditor(typeof(Player))]
//外挂的脚本因为存储在Editor目录下,所以不会被打入最终的游戏包
//不继承自Mono,而是继承自Editor
public class PlayerEditor : Editor
{//获得到需要编辑显示的组件private Player _Component;//当关联组件所在对象被添加或选中时调用private void OnEnable(){_CompOnent= target as Player;}//当关联组件所在对象被删除或取消时调用private void OnDisable(){_CompOnent= null;}//用于绘制检视面板的生命周期函数public override void OnInspectorGUI(){//标题显示EditorGUILayout.LabelField("人物相关属性");_Component.ID = EditorGUILayout.IntField("玩家ID", _Component.ID);//参数4:是否可以将场景中的对象拖给这个成员变量_Component.Weapon = EditorGUILayout.ObjectField("持有武器", _Component.Weapon, typeof(GameObject), true) as GameObject;//纹理_Component.Cloth = EditorGUILayout.ObjectField("衣服材质贴图", _Component.Cloth, typeof(Texture), false) as Texture;//单选枚举(标题, 组件上的原始值)_Component.Pro = (PlayerProfression)EditorGUILayout.EnumPopup("玩家职业", _Component.Pro);//多选枚举(标题, 组件上的原始值)_Component.LoveColor = (PlayerLoveColor)EditorGUILayout.EnumFlagsField("玩家喜欢的颜色", _Component.LoveColor);终极数据类型绘制//更新可序列化数据serializedObject.Update();//通过成员变量名找到组件上的成员变量SerializedProperty sp = serializedObject.FindProperty("Items");//可序列化数据绘制(取到的数据,标题,是否将所有获得的序列化数据显示出来)EditorGUILayout.PropertyField(sp, new GUIContent("道具信息"), true);//将修改的数据,写入到可序列化的原始数据中serializedObject.ApplyModifiedProperties();滑动条绘制//滑动条显示(1.标题,2.原始变量,最小值,最大值)_Component.Atk = EditorGUILayout.Slider(new GUIContent("玩家攻击力"), _Component.Atk, 0, 100);if (_Component.Atk > 80){//显示消息框(红色)EditorGUILayout.HelpBox("攻击力太高了", MessageType.Error);}if (_Component.Atk <20){//显示消息框(黄色)EditorGUILayout.HelpBox("攻击力太低了", MessageType.Warning);}//按钮显示和元素排列//(按钮是否被按下)显示按钮(按钮名称)GUILayout.Button("来个按钮");GUILayout.Button("来个按钮");if (GUILayout.Button("测试点击")){Debug.Log("测试点击");}//开始横向排列绘制EditorGUILayout.BeginHorizontal();GUILayout.Button("再来个按钮");GUILayout.Button("再来个按钮");//结束横向排列绘制EditorGUILayout.EndHorizontal();}
}


推荐阅读
  • java文本编辑器,java文本编辑器设计思路
    java文本编辑器,java文本编辑器设计思路 ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 云函数与数据库API实现增删查改的对比
    本文将深入探讨使用云函数和数据库API实现数据操作(增删查改)的不同方法,通过详细的代码示例帮助读者更好地理解和掌握这些技术。文章不仅提供代码实现,还解释了每种方法的特点和适用场景。 ... [详细]
  • 本文探讨了在iOS平台上开发BLE(蓝牙低功耗)应用程序时遇到的挑战,特别是如何实现应用在后台模式下仍能持续扫描并连接蓝牙设备。文章提供了具体的配置方法和常见的问题解决方案。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 20100423:Fixes:更新批处理,以兼容WIN7。第一次系统地玩QT,于是诞生了此预备式:【QT版本4.6.0&#x ... [详细]
  • Qt QTableView 内嵌控件的实现方法
    本文详细介绍了在 Qt QTableView 中嵌入控件的多种方法,包括使用 QItemDelegate、setIndexWidget 和 setIndexWidget 结合布局管理器。每种方法都有其适用场景和优缺点。 ... [详细]
  • ElasticSearch 集群监控与优化
    本文详细介绍了如何有效地监控 ElasticSearch 集群,涵盖了关键性能指标、集群健康状况、统计信息以及内存和垃圾回收的监控方法。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 本文详细介绍如何使用 Python 集成微信支付的三种主要方式:Native 支付、APP 支付和 JSAPI 支付。每种方式适用于不同的应用场景,如 PC 网站、移动端应用和公众号内支付等。 ... [详细]
  • 本文详细介绍了如何正确安装Java EE SDK,并解决在安装过程中可能遇到的问题,特别是关于servlet代码在Apache Tomcat 10中无法运行的情况。 ... [详细]
  • 微信小程序中实现位置获取的全面指南
    本文详细介绍了如何在微信小程序中实现地理位置的获取,包括通过微信官方API和腾讯地图API两种方式。文中不仅涵盖了必要的准备工作,如申请开发者密钥、下载并配置SDK等,还提供了处理用户授权及位置信息获取的具体代码示例。 ... [详细]
  • 本文详细介绍了如何在现有的Android Studio项目中集成JNI(Java Native Interface),包括下载必要的NDK和构建工具,配置CMakeLists.txt文件,以及编写和调用JNI函数的具体步骤。 ... [详细]
author-avatar
uai_128366833952
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有