【第一章编辑器开发基础第二节编辑器布局_3GUI元素和布局大小(3/4)】

布局选项

​​用途​​:精细控制元素尺寸

​​核心类​​:GUILayout

​​使用位置​​:UI元素方法末尾

​​常用选项​​:

csharp 复制代码
// 宽度约束
GUILayout.Button("文本", GUILayout.Width(80));

// 高度约束
GUILayout.Button("文本", GUILayout.Height(30));

// 同时约束宽高
GUILayout.Button("文本", 
    GUILayout.Width(100), 
    GUILayout.Height(40)
);

​​注意事项​​:

csharp 复制代码
选项必须放在参数列表末尾
不能混合GUILayout和EditorGUILayout选项
Height/Width只接受单次声明:
// 错误写法!(结果以最后一个为准)
GUILayout.Button("文本", 
   GUILayout.Height(30), 
   GUILayout.Height(50) // 此设置生效
);

// 正确写法
GUILayout.Button("文本", GUILayout.Height(50));

示例代码和效果图

csharp 复制代码
using UnityEngine;
using UnityEditor;

/// <summary>
/// 创建自定义编辑器,作用于Example组件
/// </summary>
[CustomEditor(typeof(Example))]
public class ExampleEditor : Editor
{
    
    // ================= 核心方法 - 绘制编辑器界面 =================
    public override void OnInspectorGUI()
    {
        // 1. 先绘制默认Inspector内容
        base.OnInspectorGUI();

        // 2. 依次绘制各种自定义控件
        LayoutOption();// 布局选项应用


      
    }




    // ================= 9. 布局选项应用 =================
    private void LayoutOption()
    {
        
        GUILayout.BeginHorizontal();

        // 固定宽度50像素
        GUILayout.Button("btn1", GUILayout.Width(50f));


        GUILayout.Button("btn2", GUILayout.Height(150f), GUILayout.Height(30f));

        // 同时指定宽高
        GUILayout.Button("btn3", GUILayout.Width(200f), GUILayout.Height(40f));

        GUILayout.EndHorizontal();
    }

}
相关推荐
平行云PVT5 分钟前
数字孪生信创云渲染技术解析:从混合信创到全国产化架构
linux·unity·云原生·ue5·图形渲染·webgl·gpu算力
bandaostart6 小时前
VsCode+Cmake使用说明
ide·vscode·编辑器
freshman_y6 小时前
个人VSCode一些配置记录
ide·vscode·编辑器
小小数媒成员7 小时前
Unity的包含文件
unity·游戏引擎
mxwin8 小时前
Unity Shader 实战屏幕颜色抓取实现径向模糊 (URP)
unity·游戏引擎·shader·uv
林枫依依12 小时前
Unity2017 项目源码打开即崩溃,无法打开的解决办法
unity
Chase_______13 小时前
【Linux精讲|第1章】Vi 编辑器核心三模式——命令、插入、尾行全解析
linux·运维·编辑器
拆房老料13 小时前
多人协同编辑Excel时,筛选相互干扰怎么办?Onlyoffice中国版给出了与WPS一样的答案
编辑器·excel·开源软件·wps
JavaPub-rodert13 小时前
VSCode 接入 Codex(基于 sub2api 的完整实战指南)
ide·vscode·编辑器·codex
心前阳光14 小时前
Unity使用豆包语音模型
unity·游戏引擎