unity 属性面板的绘制

最终效果:

using System;
using System.Collections;
using System.Collections.Generic;
using UnityEditor;
using UnityEngine;

[CustomEditor(typeof(BaseAttribute))] //需要重写的类
public class MyTouchJoystick : Editor
{
    BaseAttribute baseAttribute;
    bool isShowBackSetting;
    bool isShowForwardSetting;

    void OnEnable()
    {
        //获取当前编辑自定义的Inspector的对象
        baseAttribute = (BaseAttribute)target;
    }

    //自定义检视面板
    public override void OnInspectorGUI()
    {
        //设置整个布局为垂直布局
        EditorGUILayout.BeginVertical();

        //空行
        EditorGUILayout.Space();
        EditorGUILayout.Space();
        EditorGUILayout.Space();
        //绘制摇杆的背景属性
        isShowBackSetting = EditorGUILayout.Foldout(isShowBackSetting,"BackSprite:");
        if (isShowBackSetting)
        {
            //绘制背景
            baseAttribute.BackSprite = (Sprite)EditorGUILayout.ObjectField("Texture:", baseAttribute.BackSprite, typeof(Sprite), true);
            //水平绘制大小属性面板
            EditorGUILayout.LabelField("Size:");
            EditorGUILayout.BeginHorizontal();
            EditorGUILayout.Space();
            //绘制标签
            EditorGUILayout.LabelField("Width:", GUILayout.MaxWidth(50));
            //绘制可以输入的float类型
            baseAttribute.BackSpriteWidth = EditorGUILayout.FloatField(baseAttribute.BackSpriteWidth);
            EditorGUILayout.LabelField("Height:", GUILayout.MaxWidth(50));
            baseAttribute.BackSpriteHeight = EditorGUILayout.FloatField(baseAttribute.BackSpriteHeight);
            EditorGUILayout.EndHorizontal();
        }
        isShowForwardSetting = EditorGUILayout.Foldout(isShowForwardSetting, "ForwardSprite:");
        if(isShowForwardSetting)
        {
            //绘制前景
            baseAttribute.ForwardSprite = (Sprite)EditorGUILayout.ObjectField("Texture:", baseAttribute.ForwardSprite, typeof(Sprite), true);
            //水平绘制大小属性面板
            EditorGUILayout.LabelField("Size:");
            EditorGUILayout.BeginHorizontal();
            EditorGUILayout.Space();
            EditorGUILayout.LabelField("Width:", GUILayout.MaxWidth(50));
            baseAttribute.ForwardSpriteWidth = EditorGUILayout.FloatField(baseAttribute.BackSpriteWidth);
            EditorGUILayout.LabelField("Height:", GUILayout.MaxWidth(50));
            baseAttribute.ForwardSpriteHeight = EditorGUILayout.FloatField(baseAttribute.BackSpriteHeight);
            EditorGUILayout.EndHorizontal();

        }
    }
}

  

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

[ExecuteInEditMode] //不需要运行游戏即可控制图片切换
public class BaseAttribute : MonoBehaviour {

    //背景属性
    public Sprite BackSprite;
    public float BackSpriteWidth=100;
    public float BackSpriteHeight=100;

    //前景属性
    public Sprite ForwardSprite;
    public float ForwardSpriteWidth;
    public float ForwardSpriteHeight;

    void Update()
    {
        SettingBackImage();
    }

    void SettingBackImage()
    {
        this.GetComponent<Image>().sprite = BackSprite;
    }
}

1.Vertical-垂直布局 
默认的界面布局就是垂直布局,但是为了节目效果,我们还是把它写上比较好,设置元素为垂直布局需使用这对兄弟来声明:

EditorGUILayout.BeginVertical(); 
EditorGUILayout.EndVertical();

2.Horizontal-水平布局

设置元素为水平布局需使用这对兄弟来声明:

EditorGUILayout.BeginHorizontal(); 
EditorGUILayout.EndHorizontal();

3.空行 
使用 EditorGUILayout.Space() 可在两个元素之间空出一行。

4.绘制各种类型字段 
绘制字段用到以下几个方法:

EditorGUILayout.LabelField()标签字段 
EditorGUILayout.IntField() 整数字段 
EditorGUILayout.FloatField() 浮点数字段 
EditorGUILayout.TextField() 文本字段 
EditorGUILayout.Vector2Field() 二维向量字段 
EditorGUILayout.Vector3Field() 三维向量字段 
EditorGUILayout.Vector4Field() 四维向量字段 
EditorGUILayout.ColorField() 颜色字段

5.滑块、进度条 
1/ 滑块:EditorGUILayout.Slider() 
制作一个滑动条用户可以拖动来改变值,在最小和最大值之间

2/ 进度条:EditorGUI.ProgressBar()

6.帮助框 
帮助框:EditorGUILayout.HelpBox()

来源:http://blog.csdn.net/qq_33337811/article/details/62227146

时间: 2024-10-29 04:58:02

unity 属性面板的绘制的相关文章

XCode属性面板使用说明

Xcode 中Interface Builder 工具 是一个功能强大的“所见即所得”开发工具.本文主要介绍属性面板 和  对象库面板 对象库面板: 提供了所有Cocoa Touch 库给我们定义好的界面组件,包括 View 组件和 Controller 组件(所有名字带 xxxxController 的组件). 使用如下图: 默认列表显示                方格显示 对象库中组件较多,为了查找方便,底部提供了搜索栏,功能强大,一般只要输入关键的几个字母,就能快速找到你需要的组件.

c#自定义控件属性面板及选择资源设置

因为要做流体布局,但两个控件没办法组合,就做自定义控件.这个控件需要一个text设置文本,一个pic设置图片显示,图片通过选择获取,在属性面板里能够修改. 添加用户控件之后就可以自己随意设置控件内容了,这里说下关于属性的一些设置. 自定义控件显示在工具箱的开关:将true改为false就可以不显示了. [ToolboxItem(true)] public partial class UserControl1 : UserControl 自定义控件在工具箱中的图标显示:可以使用已有控件的图标, 1

[macOS]init windows position——方法一:直接在属性面板定义

打开一个应用,File/new,会打开一个窗口,这个窗口的位置我们是可以自定义的. 创建一个项目,我们用Document-Based Application做例子说这个问题. 第一个方法:属性面板定义 选中这个 在这个虚拟的屏幕可以看大概位置. 拖动灰色的方块,运行一下,关闭窗口,然后File/new,就会变成这样: 看,窗口出现在了虚拟屏幕出现的位置. 注意:macOS的坐标系统和iOS不一样,原点在左下角,iOS在左上角! 这里有个问题,mac屏幕尺寸有13‘有14’有21‘,这时修改这两个

Style3D属性面板的开发指南

类结构简介 我已经封装成了框架式程序,有固定可靠的数据流程,开发者只需完成简单的几个框架属性的编写,即可轻松完成子对话框选项卡的设计,无需手动管理物体列表的变化或者选项卡的切换.可以按照普通对话框一样任意添加各种控件,数据交换也是通过基类中Frame,Doc,三个View的指针即可实现,无需手动赋值. 两个基类: class MeshPropertyBase { CPiFrame* m_pPiFrame; CModelView* m_pModelView; CPatView* m_pPatVie

[Unity实战]虚线的绘制

说起在unity中画虚线,本人想到了两种方法: 1.无数条小直线组成一条虚线. 2.写一个shader. 前者比较简单,所以这次的重点就放在结合shader实现画虚线了. 首先,需要准备一张背景透明,仅有一条虚线的png图片,如下所示(千万不要以为背景是白色的!). 然后在场景中建一个Plane,把下面的shader给它. Shader "Custom/NewShader" { Properties { _MainTex ("Base (RGB)", 2D) = &

Unity&amp;Shader基础篇-绘制网格+圆盘

一.前言 尊重原创,转载请注明出处凯尔八阿哥专栏 上一章点击打开链接中已经画出了一个棋盘网格,首先来完善一下这个画网格的Shader,添加属性,属性包括网格的线的宽度,网格的颜色等.代码如下: Shader "Unlit/Chapter2-2" { Properties { _backgroundColor("面板背景色",Color) = (1.0,1.0,1.0,1.0) _axesColor("坐标轴的颜色",Color) = (0.0,0

Unity属性(Attributes)

Unity3d中的属性(Attributes) Attributes属性属于U3D的RunTimeClass,所以加上以下的命名空间是必须的了. using UnityEngine; using System.Collections; 0.Property Attributes变量属性(放在方括号内变量申明前)(常用) 1/ Range(min,max) 如: [SerializeField, Range(0, 5)] int count; 如: [SerializeField, Range(0

在Unity中使用uGUI绘制自定义图形(饼状图 雷达图)

饼状图或者是雷达图是根据属性自动生成的自定义图形.这里展示了如何使用uGUI完成这一功能. 先附上我制作雷达图的控件的代码  UIPropWidget.cs using UnityEngine; using System.Collections.Generic; using UnityEngine.UI; /* * * 2 6 * * 3 7 * * 0 1 5 4 * * * 2 6位为属性0 3为属性1 0为属性2 4为属性3 7为属性4 */ public class UIPropWidg

Unity检测面板旋转值超过180度成负数的离奇bug

问题描述: 无意中在检视面板上对游戏物体的tansform进行旋转,结果发现旋转超过180度成负数的离奇bug 解决方案: 创建个新的unity工程,进行如上操作,一切正常-- 怀疑问题根源是配置出现问题,比对二个工程配置完全匹配-- 经过漫长的研究,发现根源出在NGUI上,项目中并没有使用NGUI,只是添加了NGUI的文件夹-- 从asseet文件夹中删除NGUI,重新打开工程,一切恢复正常.. 原文地址:https://www.cnblogs.com/fzxiaoyi/p/8470135.h