Unity UGUI的LayoutElement(布局元素)组件的介绍及使用

1. 什么是LayoutElement组件?

LayoutElement是Unity UGUI中的一个布局元素组件,用于控制UI元素在布局中的大小和位置。它可以用于自动调整UI元素的大小,以适应不同的屏幕分辨率和布局需求。

2. LayoutElement组件的工作原理

LayoutElement组件通过设置一些属性来控制UI元素的布局,包括最小和最大宽度、最小和最大高度、宽度和高度的优先级等。当UI元素所在的布局组件(如HorizontalLayoutGroup或VerticalLayoutGroup)进行布局计算时,会根据LayoutElement的属性来确定UI元素的最终大小和位置。

3. LayoutElement组件的常用属性

  • Min Width(最小宽度):UI元素的最小宽度。
  • Min Height(最小高度):UI元素的最小高度。
  • Preferred Width(首选宽度):UI元素的首选宽度。
  • Preferred Height(首选高度):UI元素的首选高度。
  • Flexible Width(可伸缩宽度):UI元素的宽度可以根据布局需求进行伸缩。
  • Flexible Height(可伸缩高度):UI元素的高度可以根据布局需求进行伸缩。
  • Layout Priority(布局优先级):UI元素在布局计算中的优先级,用于确定UI元素的大小和位置。

4. LayoutElement组件的常用函数

  • CalculateLayoutInputHorizontal():计算UI元素在水平方向上的布局输入。
  • CalculateLayoutInputVertical():计算UI元素在垂直方向上的布局输入。

5. 例子代码

例子1:设置UI元素的最小宽度和最小高度

LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.minWidth = 100;
layoutElement.minHeight = 50;

操作步骤:

  1. 获取LayoutElement组件。
  2. 设置最小宽度为100。
  3. 设置最小高度为50。

注意事项:

  • 最小宽度和最小高度的值应根据实际需求进行调整。

例子2:设置UI元素的首选宽度和首选高度

LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.preferredWidth = 200;
layoutElement.preferredHeight = 100;

操作步骤:

  1. 获取LayoutElement组件。
  2. 设置首选宽度为200。
  3. 设置首选高度为100。

注意事项:

  • 首选宽度和首选高度的值应根据实际需求进行调整。

例子3:设置UI元素的可伸缩宽度和可伸缩高度

LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.flexibleWidth = 1;
layoutElement.flexibleHeight = 1;

操作步骤:

  1. 获取LayoutElement组件。
  2. 设置可伸缩宽度为1。
  3. 设置可伸缩高度为1。

注意事项:

  • 可伸缩宽度和可伸缩高度的值应根据实际需求进行调整。

例子4:设置UI元素的布局优先级

LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.layoutPriority = 1;

操作步骤:

  1. 获取LayoutElement组件。
  2. 设置布局优先级为1。

注意事项:

  • 布局优先级的值越大,UI元素在布局计算中的优先级越高。

例子5:计算UI元素的布局输入

LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.CalculateLayoutInputHorizontal();
layoutElement.CalculateLayoutInputVertical();

操作步骤:

  1. 获取LayoutElement组件。
  2. 调用CalculateLayoutInputHorizontal()函数计算水平方向上的布局输入。
  3. 调用CalculateLayoutInputVertical()函数计算垂直方向上的布局输入。

注意事项:

  • 在需要手动触发布局计算时,可以调用CalculateLayoutInputHorizontal()和CalculateLayoutInputVertical()函数。

参考资料

Unity UGUI的LayoutElement(布局元素)组件的介绍及使用的更多相关文章

  1. Unity UGUI

    超详细的基础教程传送门:(持续更新中) Unity UGUI之Canvas&EventSystem:http://blog.csdn.net/qq992817263/article/detai ...

  2. Unity UGUI Layout自动排版组件用法介绍

    Unity UGUI布局组件 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享 ...

  3. Unity3D UGUI强制刷新Layout(布局)组件

    UGUI的Layout布局组件确实节省了我们很多代码 如果不使用Layout组件 那么光在计算UI的布局上就要花费很大的功夫 特别是动态生成其组件的时候 当然,Layout组件在大多数时候是非常好用的 ...

  4. Unity ugui屏幕适配与世界坐标到ugui屏幕坐标的转换

    我们知道,如今的移动端设备分辨率五花八门,而开发过程中往往只取一种分辨率作为设计参考,例如采用1920*1080分辨率作为参考分辨率. 选定了一种参考分辨率后,美术设计人员就会固定以这样的分辨率来设计 ...

  5. Android开发1:基本UI界面设计——布局和组件

    前言 啦啦啦~本学期要开始学习Android开发啦~ 博主在开始学习前是完完全全的小白,只有在平时完成老师要求的实验的过程中一步一步学习~从此篇博文起,博主将开始发布Android开发有关的博文,希望 ...

  6. Unity UGUI —— 无限循环List

    还记得大学毕业刚工作的时候是做flash的开发,那时候看到别人写的各种各样的UI组件就非常佩服,后来自己也慢慢尝试着写,发现其实也就那么回事.UI的开发其实技术的成分相对来说不算多,但是一个好的UI是 ...

  7. 基于Unity·UGUI实现的RecycleList循环列表UI容器

    在UI功能开发实践中,列表UI容器是我们经常使用一种UI容器组件.这种组件就根据输入的数据集合生成对应数据项目.从显示的方向来说,一般就分为水平排布和垂直排布的列表容器两种.列表容器为了在有限的界面空 ...

  8. Unity UGUI图文混排源码(三) -- 动态表情

    这里是根据图文混排源码(二)进一步修改的,其他链接也不贴了,就贴一个链接就好了,第一次看这文章的同学可以先去看看其他几篇文章 Unity UGUI图文混排源码(二):http://blog.csdn. ...

  9. Unity UGUI之Canvas&EventSystem

    最近想写一套关于UGUI所有控件的基础使用教程系列,主要是根据本人的使用心得来写的,所以其中可能难以避免会有不正确的地方. 好了进入主题,既然是第一篇,我觉得我有必要先介绍一下UGUI必不可缺的两个组 ...

  10. Unity UGUI图文混排源码(二)

    Unity UGUI图文混排源码(一):http://blog.csdn.net/qq992817263/article/details/51112304 Unity UGUI图文混排源码(二):ht ...

随机推荐

  1. 读《mysql是怎样运行的》有感

    最近读了一本书<mysql是怎样运行的>,读完后在大体上对mysql的运行有一定的了解.在以前,我对mysql有以下的为什么: InnoDB中的表空间.段.区和页是什么? redo log ...

  2. Python 字典定义

    字典 能将相关信息关联起来 可存储的信息几乎不受限制 # 案例1 alien_0 = {'color':'green','points':5} print(alien_0['color']) prin ...

  3. 中国剩余定理(CRT)学习笔记

    约定 \(A\perp B\) 表示 \(\gcd(A,B)=1\). \(A\mid B\) 表示 \(B\equiv 0\pmod{A}(A\neq0)\). 引入 考虑以下这道题: 有物不知其數 ...

  4. selenium 执行js脚本

    使用 selenium 直接在当前页面中进行js交互 使用selenium 执行 Js 脚本 要使用 js 首先要知道 js 怎么用,现在举个简单得例子,就用12306举例子, 它的首页日期选择框是只 ...

  5. 2023-03-22:给定一个字符串str, 如果删掉连续一段子串,剩下的字符串拼接起来是回文串, 那么该删除叫做有效的删除。 返回有多少种有效删除。 注意 : 不能全删除,删成空串不允许, 字符串长

    2023-03-22:给定一个字符串str, 如果删掉连续一段子串,剩下的字符串拼接起来是回文串, 那么该删除叫做有效的删除. 返回有多少种有效删除. 注意 : 不能全删除,删成空串不允许, 字符串长 ...

  6. golang调用sdl2,键盘和鼠标事件

    golang调用sdl2,键盘和鼠标事件 win10 x64下测试成功,其他操作系统下不保证成功. 采用的是syscall方式,不是cgo方式. 见地址 代码用golang编写.代码如下: packa ...

  7. 2022-02-22:机器人大冒险。 力扣团队买了一个可编程机器人,机器人初始位置在原点(0, 0)。小伙伴事先给机器人输入一串指令command,机器人就会无限循环这条指令的步骤进行移动。指令有两种

    2022-02-22:机器人大冒险. 力扣团队买了一个可编程机器人,机器人初始位置在原点(0, 0).小伙伴事先给机器人输入一串指令command,机器人就会无限循环这条指令的步骤进行移动.指令有两种 ...

  8. 2021-08-15:给定一个字符串Str,返回Str的所有子序列中有多少不同的字面值。

    2021-08-15:给定一个字符串Str,返回Str的所有子序列中有多少不同的字面值. 福大大 答案2021-08-15: 返回值=上+新-修正. 时间复杂度:O(N) 空间复杂度:O(N). 代码 ...

  9. get()、get_or_create()、first()、last()、latest()、earliest()、in_bulk()

    get() 查询. get_or_create() 不存在时更新.存在时查询并返回. first() 获取第一笔. last() 获取最后一笔. 使用latest和earliest时需要在元数据(me ...

  10. 基于Django的简易博客系统教程

    1. 安装Django 在命令行中输入以下命令安装Django pip install django 2. 创建Django项目 在命令行中输入以下命令创建一个名为myblog的Django项目 dj ...