位置: 编程技术 - 正文

Custom List in inspector, displaying data your way[Unity]

编辑:rootadmin

推荐整理分享Custom List in inspector, displaying data your way[Unity],希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

原文地址: this Unity C# tutorial you will create a custom visualization for arrays and lists in the editor.You will learn tocreate a custom editoruse SerializedObjectmanipulate a SerializedProperty that represents an array or listuse an enumeration for option flagsuse GUI buttons

This tutorial comes after the Custom Data tutorial.

This tutorial is for Unity version 4.3 and above. The older version can still be found here.

inShare1Customized lists.Creating Test DataUnity's default way to show lists is serviceable, but it's possible to find yourself wanting for an alternative. The specifics can vary from case to case. So it would be useful if we could use a mix of different visualizations. It is possible to do this by adding attributes to variables that specify how the editor should show them.

We start with the finished Custom Data tutorial project, or by creating a new empty project and importing custom-data.unitypackage.

Then we create a new test script named ListTester with some test arrays, and make a new prefab and prefab instance with it, so we can see it all works as expected.

New test object, with wide inspector.Creating a Custom InspectorOur first step to customizing our lists is to create a custom inspector for our test component. Create a new C# script named ListTesterInspector in the Editor folder, make it extendUnityEditor.Editor, and apply the UnityEditor.CustomEditor attribute to tell Unity that we want it to do the drawing for our component.Custom inspector script.To actually change the inspector we need to override the OnInspectorGUI method of the Editorclass. Leaving the method empty will result in an empty inspector as well.Empty inspector.There are three important differences between a property drawer and an editor. Firstly, in the editor we work with an entire SerializedObject instead of a single SerializedProperty. Secondly, an instance of the editor exists as long as the object stays selected, keeping a reference to its data instead of getting it via a method parameter. Finally, we can useEditorGUILayout, which takes care of positioning for us.Custom List in inspector, displaying data your way[Unity]

We can get to the serialized object via the serializedObject property. To prepare it for editing, we must first synchronize it with the component it represents, by calling its Update method. Then we can show the properties. And after we are done, we have to commit any changes via itsApplyModifiedProperties method. This also takes care of Unity's undo history. In between these two is where we'll draw our properties.

Inspector with empty properties.The fields are visible again, but they're empty. This is because PropertyField doesn't show any children – like array elements – unless we tell it to do so.Inspector with children.Creating an Editor ListTo use a customized list in our inspector, we'll create an alternative for the PropertyFieldmethod. We will name this method Show and put it in its own static utility class, so we can use it wherever we want. We'll name this class EditorList and place it in the Editor folder.EditorList script.This method doesn't do anything yet, but we can already use it in our custom editor, resulting once again in an empty inspector.Showing a list consists of three parts, its foldout, its size, and its elements. We can show the foldout by using EditorGUILayout.PropertyField without having it show the children of the list. Then we can show the list elements ourselves with help of the arraySize property and theGetArrayElementAtIndex method of SerializedProperty. We'll leave the size for later.Lists without indented elements.Properly IndentingWe have our lists again, but their elements aren't indented. We can solve this by increasing the indent level before showing the elements, and decreasing it again afterwards.Messed up indenting.Now indentation works again, except for our color point list, which goes wrong after the first element. This is because we set the indent level to zero in our custom property drawer. There are two ways to fix this. Either our custom list should set the indent level to the correct value again after each element, or the property drawer should make sure it leaves the indent level unchanged. Let's make sure that ColorPointDrawer behaves well.Correct indenting, but no collapsing.Collapsing ListsNow that indenting works, we can take care of the next problem. Toggling the foldouts should collapse and expand the lists, but it currently doesn't work. This is easy to fix by checking theisExpanded property of our list.Correctly collapsing.Showing the SizeTo show the list's size, we can use the special relative property named Array.size. We'll simply show it in between the foldout and the elements.Why not use arraySize here?Complete lists.Customizing the ListNow that we have replicated the default list, it's time to add customizations. An easy start is to make the size that we just added optional. We add a boolean parameter to control this and turn it on by default.How does showListSize work?Using this new option, we can switch of the size for some of our lists.Hiding some of the list sizes.As a second option, let's make the list's label optional as well. If we don't show the label, we won't indent either and we will always show the elements, regardless whether the list is expanded.Now we can remove the label from some of our lists.Hiding some of the list labels.Using FlagsWhile we can keep adding options this way, our method calls will become increasingly obscure. We could add wrapper methods with more descriptive names, but that would bloat our script and isn't flexible. An alternative is the use of option flags.

The first thing we need to do is create an enumeration of all our options. We name itEditorListOption and give it the System.Flags attribute. We place it in its own script file or in the same script as EditorList, but outside of the class.

Is the Flags attribute required?Now we add entries for the two options that we already have. We also add an option for when we want nothing and for when we want the default. The default is to show both the list's label and its size. We specify this by combining both options with the bitwise OR operator |.How do bitwise flags work?The boolean parameters of the Show method can now be replaced with a single options parameter. Then we'll extract the individual options with the help of the bitwise AND operator &and store them in local variables to keep things clear.Then we can modify our custom inspector to use the new options approach.Hiding the Element LabelsAnother useful feature is the ability to hide the labels of the elements. So let's add an option for element labels and include it in the default. We can also add a convenient entry for the default without the element labels.Now all we have to do in our Show method is extract this option and perform a simple check. Let's also move the element loop to its own private method, for clarity. Hiding some of the element labels, wide and narrow.Our element labels can now be hidden, but something is wrong when we use a narrower inspector. It turns out that our color point drawer still decides to use an additional line, but without a label this is no longer useful. The solution is simply to make sure ColorPointDrawer does not claim an extra line when it does not receive a label.No longer needlessly claiming extra lines.Adding ButtonsInstead of removing parts, we can also add thing to our list. We could add a set of buttons for manipulating list elements. They can provide an alternative way to delete and duplicate elements, and we can add a means to reorder the elements as well.

First we'll add an option for buttons, and also a convenient option to activate everything.

For the button labels we'll use a simple "&#;" for duplicate, a "-" for delete, and a "↴" (rightwards arrow with corner downwards) for move. You can directly insert the arrow unicode character, but I use its escape code just to be sure everyone can copy it correctly.

We predefine static GUIContent for these buttons and include handy tooltips as well. We also add a separate method for showing the buttons and call it after each element, if desired.

Why static instead of const?Let's add these buttons to the lists for our color points and objects.Quite huge buttons.These buttons are way too large, because each claims an entire line. We want everything to stay together on a single line instead. We can instruct the automatic layout to do this by putting our content in between calls to EditorGUILayout.BeginHorizontal andEditorGUILayout.EndHorizontal.Pretty large buttons.That is a lot better, but the buttons are still too large. We'll change two things to make them behave. First, we'll apply some mini button styles to them. Second, we'll give them a fixed width of pixels each.Mini buttons.Now the buttons look fine, but they don't do anything yet.

Fortunately, adding functionality to the buttons is very simple, as we can directly use the methods for array manipulation provided by SerializedProperty. We need the list and the current element index for this to work, so we add them as parameters to our ShowButtons method and pass them along inside the loop of ShowElements.

How does Button work?What happens when we move the bottom element?What are the contents of a new item?Our buttons now work as expected. Or do they? Try deleting an element from the objects list. If it references no component, it works. But if it does reference something, it will clear the reference, but not remove the element from the list.

While this is how Unity handles deletion in this case, it is weird. Instead, we want the element to always be removed, not sometimes cleared. We can enforce this by checking whether the list's size has remained the same after deleting the element. If so, it has only been cleared and we should delete it again, for real this time.

An additional button we could include is one to add an element when the list is empty. This is useful when we're not showing the list size, because in that case you could neither duplicate an element nor manipulate the list size directly. So let's add such a button.A big add button.Only Allowing ListsWhat would happen if we would try to use our editor list with something that isn't a list at all? Let's find out by adding something to ListTester that is not a list.Now also try to show it in ListTestInspector.Not a list shown.It actually works for our integer. But it's not guaranteed to work for any arbitrary type and it will also result in errors for some options. It is a better idea to flatly refuse to show anything that isn't a list. So let's check whether the property is an array. If it isn't, we display a nicely formatted warning and nothing else.Only lists allowed.Multi-object EditingAnother interesting point is multi-object editing. You can test this by duplicating our list tester object, make them a little different, and selecting both at the same time.No multi-object editing yet.By default custom editors do not support multi-object editing, though that is easily fixed by adding the CanEditMultipleObjects attribute to our ListTesterInspector.Multi-object editing.While this can be useful, it gets weird when you're editing multiple objects that have lists of different sizes. In general it is not very useful and might even be drawn wrong. So let's not show the list's elements when we have multiple different sizes.Divergent lists will not be shown.We now have a generic list drawer with four customization options that you can use instead of the default list representation. Quite handy!

Unity NGUI添加事件监听(转摘) usingUnityEngine;usingSystem.Collections;usingUnityEngine.UI;usingUnityEngine.EventSystems;usingUnityEngine.Events;publicclassUIMain:MonoBehaviour{Buttonbutton;Imageimage;voidStart(){button=transform.

Unity光照烘焙后,在PC上曝光,发布移动平台正常的解决方法 Unity在Windows下默认使用的是DX,使用OpenGL就能解决过曝的问题,添加Unity的启动参数force-opengl,例如下面:在unity.exe的快捷方式中写上exe路径-force-opengl安

CustomPropertyDrawer-Change the height of Property field Thelastblogpostdidn'tcoveracertainniftymethodinPropertyDrawer,whichistheGetPropertyHeight.GetPropertyHeight:Determinestheheightinpixelofthepropertyfield.OverridingGetPropertyHeightthereforeallowsyouto

标签: Custom List in inspector, displaying data your way[Unity]

本文链接地址:https://www.jiuchutong.com/biancheng/377322.html 转载请保留说明!

上一篇:numix-cicle圆形图标(圆形图表分析怎么做)

下一篇:Unity NGUI添加事件监听(转摘)

  • 组成计税价格是销售额吗
  • 公司购买的车辆可以抵扣进项税吗
  • 收到退回的款项怎么做分录
  • 土建工程维修
  • 税收优惠退税会计处理
  • 小规模税控设备维护费怎么填申报表格
  • 为什么差额征税有的可以开专票有的只能开普票
  • 无形资产可以一次性摊销吗?
  • 其他应付款是不是长期负债
  • 51电子发票客户端后使用教程
  • 如何去办理小型微利企业资格每年都需要认证吗?
  • 旅游开发公司有什么职位
  • 销售返利计入什么科目
  • 委托加工物资加工完毕验收入库后作为
  • 一般纳税人可以简易计税的有哪些
  • 租入的固定资产属于资产吗
  • 建筑业开具发票新规定
  • 水资源税的纳税义务人
  • 物业公司要怎么开水电费证明
  • 含税价标志有无影响
  • 外贸企业出口转内销过程中面临的问题
  • 录入凭证时记账的依据是
  • 服务业结转成本怎么算
  • 出租柜台收取的服务费
  • 收购企业收购方和被收购方如何做账?
  • 小规模纳税人发生销售退回如何申报
  • 退回的企业所得税如何在报表中显示
  • 应交税费年末账务处理
  • 鸿蒙实用工具在哪里
  • 公司给客户报销费用可以吗
  • 纳税人逾期申报
  • 付款结算单范本
  • php输出姓名
  • php保存数据
  • php技巧
  • 小规模纳税人结转损益会计分录
  • 喜马拉雅山脉中最高的山峰是什么
  • 基础知识讲解
  • nvidia显卡驱动怎么安装
  • 非货币性资产交换补价大于25%的会计处理
  • php抽奖程序源码
  • 应交税费会计分录例题
  • 通俗易懂的炒货店名字
  • css中的hover属性
  • linux定时任务详解
  • 一般纳税人之间转让土地使用权交哪些税金
  • 收到货款的会计分录怎么做账
  • 什么叫现金流量表举例说明
  • 购买商品或服务的人称为
  • 汇算清缴报表填报顺序
  • 开票key
  • 内部往来划账通知单
  • 去年少交的增值税可以和今年的合并吗
  • 财产转让按什么计征
  • 绩效工资定义及标准
  • 给员工单独买的西装会计分录
  • 计提坏账准备的会计分录
  • 损益类科目如何结转本年利润
  • 购入房屋建筑物进项税额抵扣
  • 转让固定资产的税率
  • 托管服务费开什么发票
  • 如何处理消防安全事件
  • 净利润和毛利润的区别公式
  • 变更法人需要什么条件
  • 日记账公式怎么设置
  • jdbc连接MySQL实验总结
  • 盗版win8 1升级win10
  • win10睡眠什么意思
  • ubuntu20.04亮度调节
  • mac怎么访问windows
  • win7升级到win10有无影响
  • win10盘符怎么看
  • windows 10一
  • 全面解析A型天秤座男
  • javascript学习指南
  • python访问oracle
  • 个体逾期未申报一天会怎么样
  • 一般纳税人销售收入分录
  • 车辆购置税退税需要什么资料
  • 河北地税网上申报纳税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设