Unity UGUI的LayoutElement(布局元素)组件的介绍及使用
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;
操作步骤:
- 获取LayoutElement组件。
- 设置最小宽度为100。
- 设置最小高度为50。
注意事项:
- 最小宽度和最小高度的值应根据实际需求进行调整。
例子2:设置UI元素的首选宽度和首选高度
LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.preferredWidth = 200;
layoutElement.preferredHeight = 100;
操作步骤:
- 获取LayoutElement组件。
- 设置首选宽度为200。
- 设置首选高度为100。
注意事项:
- 首选宽度和首选高度的值应根据实际需求进行调整。
例子3:设置UI元素的可伸缩宽度和可伸缩高度
LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.flexibleWidth = 1;
layoutElement.flexibleHeight = 1;
操作步骤:
- 获取LayoutElement组件。
- 设置可伸缩宽度为1。
- 设置可伸缩高度为1。
注意事项:
- 可伸缩宽度和可伸缩高度的值应根据实际需求进行调整。
例子4:设置UI元素的布局优先级
LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.layoutPriority = 1;
操作步骤:
- 获取LayoutElement组件。
- 设置布局优先级为1。
注意事项:
- 布局优先级的值越大,UI元素在布局计算中的优先级越高。
例子5:计算UI元素的布局输入
LayoutElement layoutElement = GetComponent<LayoutElement>();
layoutElement.CalculateLayoutInputHorizontal();
layoutElement.CalculateLayoutInputVertical();
操作步骤:
- 获取LayoutElement组件。
- 调用CalculateLayoutInputHorizontal()函数计算水平方向上的布局输入。
- 调用CalculateLayoutInputVertical()函数计算垂直方向上的布局输入。
注意事项:
- 在需要手动触发布局计算时,可以调用CalculateLayoutInputHorizontal()和CalculateLayoutInputVertical()函数。
参考资料
- Unity官方文档:LayoutElement
Unity UGUI的LayoutElement(布局元素)组件的介绍及使用的更多相关文章
- Unity UGUI
超详细的基础教程传送门:(持续更新中) Unity UGUI之Canvas&EventSystem:http://blog.csdn.net/qq992817263/article/detai ...
- Unity UGUI Layout自动排版组件用法介绍
Unity UGUI布局组件 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享 ...
- Unity3D UGUI强制刷新Layout(布局)组件
UGUI的Layout布局组件确实节省了我们很多代码 如果不使用Layout组件 那么光在计算UI的布局上就要花费很大的功夫 特别是动态生成其组件的时候 当然,Layout组件在大多数时候是非常好用的 ...
- Unity ugui屏幕适配与世界坐标到ugui屏幕坐标的转换
我们知道,如今的移动端设备分辨率五花八门,而开发过程中往往只取一种分辨率作为设计参考,例如采用1920*1080分辨率作为参考分辨率. 选定了一种参考分辨率后,美术设计人员就会固定以这样的分辨率来设计 ...
- Android开发1:基本UI界面设计——布局和组件
前言 啦啦啦~本学期要开始学习Android开发啦~ 博主在开始学习前是完完全全的小白,只有在平时完成老师要求的实验的过程中一步一步学习~从此篇博文起,博主将开始发布Android开发有关的博文,希望 ...
- Unity UGUI —— 无限循环List
还记得大学毕业刚工作的时候是做flash的开发,那时候看到别人写的各种各样的UI组件就非常佩服,后来自己也慢慢尝试着写,发现其实也就那么回事.UI的开发其实技术的成分相对来说不算多,但是一个好的UI是 ...
- 基于Unity·UGUI实现的RecycleList循环列表UI容器
在UI功能开发实践中,列表UI容器是我们经常使用一种UI容器组件.这种组件就根据输入的数据集合生成对应数据项目.从显示的方向来说,一般就分为水平排布和垂直排布的列表容器两种.列表容器为了在有限的界面空 ...
- Unity UGUI图文混排源码(三) -- 动态表情
这里是根据图文混排源码(二)进一步修改的,其他链接也不贴了,就贴一个链接就好了,第一次看这文章的同学可以先去看看其他几篇文章 Unity UGUI图文混排源码(二):http://blog.csdn. ...
- Unity UGUI之Canvas&EventSystem
最近想写一套关于UGUI所有控件的基础使用教程系列,主要是根据本人的使用心得来写的,所以其中可能难以避免会有不正确的地方. 好了进入主题,既然是第一篇,我觉得我有必要先介绍一下UGUI必不可缺的两个组 ...
- Unity UGUI图文混排源码(二)
Unity UGUI图文混排源码(一):http://blog.csdn.net/qq992817263/article/details/51112304 Unity UGUI图文混排源码(二):ht ...
随机推荐
- APISIX 是怎么保护用户的敏感数据不被泄露的?
本文以 APISIX 作为例子,为大家介绍了如何借助 Global Data Encryption 功能来保护敏感数据,确保不会有任何敏感数据进行明文存储,这样即使 etcd 中所有存储的数据都被盗取 ...
- 05-打包样式资源(编写webpack配置文件)
/** * webpack.config.js webpack的配置文件 * 作用:指示 webpack 干哪些活(当你运行 webpack 指令时,会加载里面的配置) * * 所有构件工具都是基于n ...
- python数据可视化神库:Matplotlib快速入门
Matplotlib易于使用,是Python中了不起的可视化库.它建立在NumPy数组的基础上,旨在与更广泛的SciPy堆栈一起工作,并由几个图组成:线图.条形图.散点图.直方图等. 快速入门 imp ...
- Python变量的数据类型
主要内容 jupyter notebook的用法 变量 跟vi/vim的编辑模式很像 # 声明的三种格式 # 格式1 s1 = "我爱王晓静" # 格式2 s2 = s1 = &q ...
- 机器学习02-(损失函数loss、梯度下降、线性回归、评估训练、模型加载、岭回归、多项式回归)
机器学习-02 回归模型 线性回归 评估训练结果误差(metrics) 模型的保存和加载 岭回归 多项式回归 代码总结 线性回归 绘制图像,观察w0.w1.loss的变化过程 以等高线的方式绘制梯度下 ...
- lombok版本报错问题java.lang.IllegalAccessError: class lombok.javac.apt.LombokProcessor (in unnamed module
lombok版本报错问题 记录一个项目部署时遇到的问题,我本地采用的JDK8的版本,然后我的服务器采用的是JDK17,然后在用maven进行打包的时候,发现package失败. 复现 我在本地采用的l ...
- 【CSS】使元素在父元素中居中显示的几种方法
在页面元素布局时经常会有把元素居中的需求,大多都是用弹性盒或者定位,下面来说一下使用方法 一.使用边距进行固定位置 这种方法需要把父元素和子元素的宽度固定,然后利用二者宽高之差添加边距移动元素的位置 ...
- #Powerbi 季度时间进度计算
上一篇我们学习了月度时间进度的计算方法,今天我们学习季度时间进度的测算. 思路:找出目前共计消耗了多少天(季度),目前日期所在的季度共有多少天,两者相除即是季度的时间进度 首先列出DAX函数: 本 ...
- golang调用sdl2,播放yuv视频
golang调用sdl2,播放yuv视频 win10 x64下测试成功,其他操作系统下不保证成功. 采用的是syscall方式,不是cgo方式. 见地址 代码如下: package main impo ...
- 2021-10-09:杨辉三角。给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。在「杨辉三角」中,每个数是它左上方和右上方的数的和。力扣118。
2021-10-09:杨辉三角.给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行.在「杨辉三角」中,每个数是它左上方和右上方的数的和.力扣118. 福大大 答案2021-10 ...