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. API Gateway vs Load Balancer:选择适合你的网络流量管理组件

    本文从对比了 API Gateway 和 Load Balancer 的功能区别,帮助读者更好地了解他们在系统架构中扮演的角色. 作者陈泵,API7.ai 技术工程师. 原文链接 由于互联网技术的发展 ...

  2. mysql安装my.cnf配置

    进入my.cnf文件//乱码修改 设置编码 character_set_server = utf8mb4 //编码 collation-server = utf8mb4_general_ci //连接 ...

  3. vue将页面(dom元素)转换成图片,并保存到本地

    1 npm install html2canvas --save <template> <div class="QRCode-box"> <img i ...

  4. 禁用Chrome浏览器Websocket

    前言:最近遇到关于Websocket的相关测试,推荐一个禁用Chrome浏览器Websocket的扩展插件 一.下载使用 1.https://github.com/arthepsy/chrome-di ...

  5. 2021-11-14:Fizz Buzz。给你一个整数 n ,找出从 1 到 n 各个整数的 Fizz Buzz 表示,并用字符串数组 answer(下标从 1 开始)返回结果,其中:answer[i

    2021-11-14:Fizz Buzz.给你一个整数 n ,找出从 1 到 n 各个整数的 Fizz Buzz 表示,并用字符串数组 answer(下标从 1 开始)返回结果,其中:answer[i ...

  6. 2021-11-04:计算右侧小于当前元素的个数。给你`一个整数数组 nums ,按要求返回一个新数组 counts 。数组 counts 有该性质: counts[i] 的值是 nums[i] 右

    2021-11-04:计算右侧小于当前元素的个数.给你`一个整数数组 nums ,按要求返回一个新数组 counts .数组 counts 有该性质: counts[i] 的值是 nums[i] 右侧 ...

  7. SpringBoot源码学习4——SpringBoot内嵌Tomcat启动流程源码分析

    系列文章目录和关于我 零丶引入 我在初学spring的时候,很懵逼,因为整个项目中不存在main方法,让我有点摸不着头脑.那时候我知道有个东西叫tomcat是它监听了端口,解析了协议调到了我的serv ...

  8. Java商城网站系统设计与实现(带源码)

    基于Java的商城网站系统设计与实现 功能介绍 平台采用B/S结构,后端采用主流的Springboot框架进行开发,前端采用主流的Vue.js进行开发. 整个平台包括前台和后台两个部分. 前台功能包括 ...

  9. 源端为备库的场景下Duplicate失败问题

    环境: Oracle 11.2.0.3 + OEL 7.9 A -> B -> C 级联ADG环境:db11g -> db11gadg -> db11gcas 之前测试提到,从 ...

  10. docker +node 部署vue项目的心路历程

    最近自己做了个小项目,试着使用docker来进行发布,而其中用到了node做跨越代理,就是为了解决这个问题至少多花费了我一天时间,不说了直接进入主题吧 step 1 部署环境 1 安装 centos ...