UGUI 有很多的自动布局组件,如下:
data:image/s3,"s3://crabby-images/e3e12/e3e123f0a4e416be74314a44fc4bfd3583ffc075" alt=""
- Layout Element 自动布局组件
- Horizontal Layout Group 水平布局组件
- Vertical Layout Group 垂直布局组件
- Grid Layout Group 网格布局组件
- Content Size Fitter 内容大小适配器
- Aspect Ratio Fitter 宽高比适配器
Layout Element 自动布局组件
data:image/s3,"s3://crabby-images/75587/755877e70924f462596cde2edc0b221bd499b903" alt=""
属性
属性 | 介绍 |
---|---|
Min Width | 最小宽度 |
Min Height | 最小高度 |
Preferred Width | 优先宽度 |
Preferred Height | 优先高度 |
Flexible Width | 弹性宽度 |
Flexible Height | 弹性高度 |
Layout Priority | 布局优先 |
Layout Element 组件对子对象的分配原则如下:
- 首先分配 Min Width、Min Height
- 如果还有足够空间,分配 Preferred Width、Preferred Height
- 如果还有额外空间,分配 Flexible Width、Flexible Height
实例
将 Layout Element 组件的属性值设置如下:
data:image/s3,"s3://crabby-images/5fc46/5fc46934f9ea814719c4e75ae490ec364f23f1e4" alt=""
data:image/s3,"s3://crabby-images/c14ec/c14ec72cce66f2fb3d459598f9957558ce961454" alt=""
- 首先分配 Min Width (300,红色部分)
- 如果还有足够空间,分配 Preferred Width (300~500,绿色部分)
- 如果还有额外空间,分配 Flexible Width :1 (500~700,蓝色部分)
值得注意的是 Flexible,他是代表著整个大小的比例,如果 Layout 下有2个物体,分别给 Flexible 设定为 0.3 与 0.7,那比例就会变成下图 :
data:image/s3,"s3://crabby-images/481b6/481b6d7bd4115cc1d05e0dc368f46daac9e7d53b" alt=""
另外要注意的是,Text、Image Component 会根据内容大小自动分配 Preferred Size
Horizontal Layout Group 水平布局组件
data:image/s3,"s3://crabby-images/02d06/02d06eacd6f231cd3b82e7e6fec677fbc471fb7a" alt=""
属性
属性 | 说明 |
---|---|
Padding | 填充内部空间 |
Spacing | 每个元素间隔 |
Child Alignment | 当没有填满全部空间时,子物件对齐位置 |
Child Controls Size | 按照子控件大小填满空间 |
Child Force Expand | 强制控制子控件填满空间 |
实例
- 新建一个场景,新建一个Canvas,在Canvas添加一个空对象命名为Layout Controllers。
- 给空对象添加Horizontal Layout Group组件:"AddConpent→Layout → Horizontal Layout Group"
- Layout Controllers下建立5个 Button(子物件),完成后如下,当大小改变时会自动分配子物件大小:
data:image/s3,"s3://crabby-images/40ce6/40ce6861359a0aba9ee4f882d21e3d38594c24b2" alt=""
- 此时在 Button 的 Rect Transform Component 就不能进行调整,因为我们已经透过 Horizontal Layout Group 进行分配空间,在 Rect Transform 会显示目前被哪个 Layout Group 控制:
data:image/s3,"s3://crabby-images/1e1e6/1e1e619570d48ef62dfab4817781857076e3054f" alt=""
- 将 Padding 数值调整如图,可以看出内边距
data:image/s3,"s3://crabby-images/cb1f8/cb1f876d9b87fa8bf322a8d45d85044bc6073487" alt=""
- 将 Spacing 数值调整如图,可以看出元素区间
data:image/s3,"s3://crabby-images/48ba4/48ba4265e70125ee76be8d095f810280c286c9d7" alt=""
- 给5个Button添加 Layout Element 组件,然后将它们的父物体身上的 Horizontal Layout Group 组件的 Child Force Expand Width 属性取消勾选,不强制子物件填满额外空间,而是透过 Layout Element 手动设定。
- 将5个 Button 的 Layout Element Min Width 分别改为 20、30、40、50、60,此时可以看出每个 Button 宽度分布,改变父物件大小时子物件大小并不会改变,因为只有分配 Min Width,并不会分配额外有效空间:
data:image/s3,"s3://crabby-images/80bfd/80bfd89402a708fdbbf7f2a2e0e969cba0971db3" alt=""
此时改变 Horizontal Layout Group 的 Child Alignment,可以看出元素对齐:
data:image/s3,"s3://crabby-images/d1d56/d1d56f05165249ee2a9f8d70b559650456a3e498" alt=""
物件 Layout Properties Min Width = 5个按钮宽(20+30+40+50+60=200
) + Spacing(40
) + Padding Left、Right(20
) = 260
:
data:image/s3,"s3://crabby-images/00bcf/00bcfa98dbe3dd464792c001c80d951208ad89d3" alt=""
- 将第1个 Button 的 Layout Element 数值调整:设置 Preferred Width 为 100、设置 Min Width 为 20,空间足够的情况下,将会分配剩下的 Preferred Size (20~100 空间),效果如下:
data:image/s3,"s3://crabby-images/95b27/95b27b41be4c04cce690183757f8834d975f41a1" alt=""
- 继续将第一个 button 设置 Flexible Width 为 1,效果如下:
data:image/s3,"s3://crabby-images/6d2f9/6d2f91b79e2ca71590cf32771bc10223d0684751" alt=""
- 如果不单让第一个 button 宽度填满剩余空间,而是让所有子游戏对象填满 ,则将 Horizontal Layout Group 的 Child Force Expand Width 勾选,效果如下:
data:image/s3,"s3://crabby-images/fb3d3/fb3d3514e057527ff8fb6db7551ad1381f89874c" alt=""
Vertical Layout Group 垂直布局组件
效果同 Horizontal Layout Group 组件,只不过参考轴是水平轴和垂直轴的区别
Grid Layout Group 网格布局组件
data:image/s3,"s3://crabby-images/5d3e6/5d3e64f61b62c95ba7f70384d99e1e2716663353" alt=""
属性 | 说明 |
---|---|
Padding | 填充内部空间 |
Cell Size | 每个元素的宽度和高度 |
Spacing | 每个元素间隔,上下间隔,左右间隔 |
Start Corner | 开始排列的角落(位置),又分为 "左上"、"右上"、"左下"、"右下" |
Start Axis | 开始排列的轴,"水平" 或是 "垂直" 排列 |
Child Alignment | 当没有填满全部空间时,子物件对齐位置 |
Constraint | 排列限制 |
下面就演示一下各个参数的效果:
Cell Size设置每个元素的宽度和高度
data:image/s3,"s3://crabby-images/b1ea3/b1ea3b98e848f0e59696005a28a1386fa00cff03" alt=""
Start Corner:开始排列的角落(分别为"左上"、"右上"、"左下"、"右下")
data:image/s3,"s3://crabby-images/13add/13add98c33803dfc611d3249b5e7a96c49e807f3" alt=""
Start Axis:开始排列的轴,"水平" 或是 "垂直" 排列
data:image/s3,"s3://crabby-images/d5a83/d5a837ef5953f4e222aacd5a48c4f847a4f731bc" alt=""
Content Size Fitter 内容大小适配器
首先,看一下这个组件的属性:
data:image/s3,"s3://crabby-images/6e037/6e037f920f47a29eb8e06b7f49f7efc704fa80a3" alt=""
这个组件控制着父物体的自身的大小,大小取决于子物体,或者是设定的大小比例。
属性 | 介绍 |
---|---|
Horizontal Fit | 水平适应调整 |
Vertical Fit | 垂直适应调整 |
Horizontal、Vertical Fit有三个参数:
参数 | 介绍 |
---|---|
None | 不调整 |
Min Size | 根据子物件的 Min Width大小进行调整 |
Preferred Size | 根据子物件的 Preferred 大小进行调整 |
接下来,通过一个实例来演示这个组件的用法:
如果我们现在有一个需求,必需要让 "父物件大小" 根据 "子物件大小" 进行缩放,完成如下:
data:image/s3,"s3://crabby-images/6d374/6d3740672bb94a14602bdc5fecf201af596f766f" alt=""
- 新建场景,新建一个Canvas,Canvas下新增空物体,给空物体增加Horizontal Layout Group组件。这时如果增加 Button(子物件),上面有提到,Horizontal Layout Group 会根据子物件的 Layout Element 进行分配子物件大小,而不会修改父物件本身的大小,如下所示:
data:image/s3,"s3://crabby-images/bddd0/bddd0e131b079fa7ab26b7463449a69d8736c322" alt=""
- 父物件下增加 Button(子物件 ),并增加 Layout Element 组件 ,Min Width 调整为 100。
- 父物件增加 Content Size Fitter 组件 ,Horizontal Fit 调整为
Min Size
,透过子物件 Min Width 调整父物件本身大小 。
data:image/s3,"s3://crabby-images/6bb29/6bb29c794c3d6f36916ce2ea9ff2915ad742de00" alt=""
- 此时如果 Button 复制增加,父物件本身的大小也会跟着改变,如下所示:
data:image/s3,"s3://crabby-images/6d374/6d3740672bb94a14602bdc5fecf201af596f766f" alt=""
- 调整父物件的 pivot,可以控制缩放方向,如下所示:
data:image/s3,"s3://crabby-images/8f656/8f6569a2b31fb03126df109b439beffbe82ed1ca" alt=""
通过上面实例,我们首先使用 Horizontal Layout Group 排列子物件,并在子物件增加 Layout Element 设置Min Width。
最后通过 Content Size Fitter 取得子物件 Layout Element 设定父物件大小。
至此父物件大小就会根据子物件大小进行缩放。
Aspect Ratio Fitter 宽高比适配器
首先,我们来看一下Aspect Ratio Fitter 长宽比装配组件的属性:
data:image/s3,"s3://crabby-images/06937/06937f4c7b6163ed8b19784fb42567691864711f" alt=""
属性介绍:
属性 | 介绍 |
---|---|
Aspect Mode | 调整模式 |
Aspect Ratio | 比例,此数值为 宽/高 |
调整模式介绍:
data:image/s3,"s3://crabby-images/e36dc/e36dc8702a47139879385b7658f420a59aa2cf33" alt=""
调整模式 | 介绍 |
---|---|
None | 不调整 |
Width Controls Height | 基于 Width 为基准,依据比例改变 Height |
Height Controls Width | 基于 Height 为基准,依据比例改变 Width |
Fit In Parent | 依据比例将 宽高、位置、anchors自动调整,使此图形大小在父物件中完全贴齐,此模式可能不会包覆所有空间调整比例 |
Envelope Parent | 依据比例将 宽高、位置、anchors自动调整,使此图形大小完全包覆父物件,此模式可能会超出空间调整比例 |
下面就演示一下各种调整模式下的情况:
- Width Controls Height:基于 Width 为基准,依据比例改变 Height
data:image/s3,"s3://crabby-images/5a31c/5a31c9ca8a6c62b3db31aa87873bcef98ec1d0e4" alt=""
当 Width 改变时,Height 会依比例改变:
data:image/s3,"s3://crabby-images/3eacd/3eacd2e445f9a788b715598d6acf3e10f32dc052" alt=""
- Height Controls Width:基于 Height 为基准,依据比例改变 Width
data:image/s3,"s3://crabby-images/e090f/e090fc678e3e225bde2c920e486ab0754d5a655b" alt=""
当 Height 改变时,Width 会依比例改变:
data:image/s3,"s3://crabby-images/2592c/2592c9b56bebcc70db1765b412a5a91ff53f647b" alt=""
- Fit In Parent:依据比例将 宽高、位置、anchors自动调整,使此图形大小在父物件中完全贴齐,此模式可能不会包覆所有空间调整比例
data:image/s3,"s3://crabby-images/577d2/577d218dd01d8a978370830c1b8001cb1a42e594" alt=""
调整父物件大小,物体会依据比例贴齐父物件:
data:image/s3,"s3://crabby-images/d3f47/d3f479f3c8e3f97ae79a5387d87437f1f58e4ba9" alt=""
- Envelope Parent:依据比例将 宽高、位置、anchors自动调整,使此图形大小完全包覆父物件,此模式可能会超出空间调整比例
data:image/s3,"s3://crabby-images/31730/31730e4f63b618b6fa6b1a6f775989c52848dfda" alt=""
调整父物件大小,物体会依据比例包覆父物件:
data:image/s3,"s3://crabby-images/25c72/25c724a04b54b96ef7f22b65c446ef37f8bd15b5" alt=""
Content Size Fitter 与 Aspect Ratio Fitter 的区别:
- Content Size Fitter 是通过子物件自动进行调整大小
- Aspect Ratio Fitter 是通过**数值(宽高比)**进行调整