博客
关于我
Unity3d自定义枚举多选
阅读量:610 次
发布时间:2019-03-12

本文共 1061 字,大约阅读时间需要 3 分钟。

Unity3D中的枚举类型通常默认为单选,但有时候我们需要实现多选功能。这只需要通过脚本实现即可。以下是具体实现步骤:

实现多选枚举的步骤

首先,我们需要创建两个新的C#脚本:EnumFlagsEnumFlagsDrawer

1. 创建EnumFlags脚本

打开EnumFlags脚本,添加如下代码:

using UnityEngine;public class EnumFlags : PropertyAttribute{}

这个脚本继承自PropertyAttribute,用来为属性添加自定义属性。这里不需要额外的字段,仅仅是标记我们的属性应受EnumFlagsDrawer处理。

2. 创建EnumFlagsDrawer脚本

打开EnumFlagsDrawer脚本,添加如下代码:

using UnityEngine;using UnityEditor;[CustomPropertyDrawer(typeof(EnumFlags))]public class EnumFlagsAttributeDrawer : PropertyDrawer{    public override void OnGUI(Rect position, SerializedProperty property, GUIContent label)    {        property.intValue = EditorGUI.MaskField(position, label, property.intValue,                                            property.enumNames);    }}

这个脚本继承自PropertyDrawer,添加了一个OnGUI方法。这个方法定义了如何绘制属性界面。当使用EnumFlags属性时,OnGUI会使用EditorGUI.MaskField绘制一个多选框。

3. 实现多选功能

在脚本中使用如下方式:

public enum solt{    solt1,    solt2,    solt3}[sazenFlags]public solt example = solt.solt1;
  • solt1solt2solt3是枚举值。
  • [sazenFlags]注释添加到枚举属性上(可以根据项目需要调整注释名称)。

这样,下一次在Unity中编辑这些属性时,EnumFlagsDrawer会将它们作为多选框显示。

转载地址:http://rqzxz.baihongyu.com/

你可能感兴趣的文章
npm scripts 使用指南
查看>>
npm should be run outside of the node repl, in your normal shell
查看>>
npm start运行了什么
查看>>
npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
查看>>
npm 下载依赖慢的解决方案(亲测有效)
查看>>
npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
查看>>
npm.taobao.org 淘宝 npm 镜像证书过期?这样解决!
查看>>
npm—小记
查看>>
npm上传自己的项目
查看>>
npm介绍以及常用命令
查看>>
NPM使用前设置和升级
查看>>
npm入门,这篇就够了
查看>>
npm切换到淘宝源
查看>>
npm切换源淘宝源的两种方法
查看>>
npm前端包管理工具简介---npm工作笔记001
查看>>
npm包管理深度探索:从基础到进阶全面教程!
查看>>
npm升级以及使用淘宝npm镜像
查看>>
npm发布包--所遇到的问题
查看>>
npm发布自己的组件UI包(详细步骤,图文并茂)
查看>>
npm和package.json那些不为常人所知的小秘密
查看>>