Unity3D文档像看国内教课书一样,一些概念,不懂的时候看还是不懂,明白了以后再看,好像也没有说错。好几个做Unity3D的朋友跟我吐槽过U3D的文档质量,相比Apple贴心的技术文档相去甚远。

话虽这么说,权威的资料当然还是官方的,建议先仔细读一遍,不懂的再往下读:
http://docs.unity3d.com/Manual/UISystem.html

网上的教程大多泛泛而谈,就不吐槽了。好在还找到了一篇比较好的解读,在此谢谢作者白猫。文章链接在下面
http://www.cnblogs.com/whitecat/p/4159815.html

uGUI里面AutoLayout比较特别,我就此详细描述一下,希望能减少“教科书”的理解障碍。

RectTransform的理解

UI元素有专门的RectTransform组件来描述元素的几何信息,继承于Transform,Inspector中其属性如下图。

RectTransform属性

Anchors,锚点

我们首先需要认识Anchors。官网上的图片很好表达了Andhors的功能,请恕我实践下拿来主义。

锚点全在中间的情况

锚点全在右下角的情况

锚点在两个角的情况

锚点分开的情况

善于观察的同学可能已经发现,不管什么情况,button的四个顶点到相应锚点的相对位置是不变的:

规律:button的四个顶点到相应锚点的相对位置是不变的

当4个锚点都在一起的时候,RectTransform会显示Pos X,Pos Y,Width,Height四个属性可供修改。

当4个锚点都在一起

当不在一起的时候,RectTransform可调整的属性会有变化。

锚点不在一起的时候,Inspector中变化1

锚点不在一起的时候,Inspector中变化2

锚点不在一起的时候,Inspector中变化3

Anchors的Min和Max分别是正规化的值(从0到1),表示占父RectTransform的百分比,下图中AnchorMin=(0.1,0.1) AnchorMax=(0.9,0.9)

AnchorMin、AnchorMax

Pivot,UI的中心点

UI元素的旋转和缩放是围绕pivot进行的。RectTransform组件中,Pivot属性是一个正规化的二维向量,用来描述中心点在本身矩形大小的位置。默认值为(0.5, 0.5),即几何中心。

以上是RectTransform可视化的编辑属性,实际上RectTransform类的属性是怎样的?查阅RectTransform的官方文档如下:

anchoredPosition
The position of the pivot of this RectTransform relative to the anchor reference point.

anchoredPosition3D
The 3D position of the pivot of this RectTransform relative to the anchor reference point.

anchorMax
The normalized position in the parent RectTransform that the upper right corner is anchored to.

anchorMin
The normalized position in the parent RectTransform that the lower left corner is anchored to.

offsetMax
The offset of the upper right corner of the rectangle relative to the upper right anchor.

offsetMin
The offset of the lower left corner of the rectangle relative to the lower left anchor.

pivot
The normalized position in this RectTransform that it rotates around.

rect
The calculated rectangle in the local space of the Transform.

sizeDelta
The size of this RectTransform relative to the distances between the anchors.

乍一看有点费解,这里有必要解释下:

anchoredPosition

可以理解为Pivot点相对于Anchor reference点的位置。Anchor reference点,我是这样理解的:当四个anchors点在一起的时候,这个点就是anchor reference点;否则这四个点的中心点就是anchor reference点。
照这个推理,anchorMax和anchorMin的值将影响anchoredPosition的值。具体还需要demo研究来确认。

但可以确定的是,当一个UI元素不需要自动拉伸行为时,用anchoredPosition + sizeDelta来设置位置和大小是比较方便的方法。

anchorMax、anchorMin和Inspector中的意义一致,需要注意的是,当UI元素不需要自动拉伸时,AnchorMax和AnchorMin是相等的。

AnchorMin与AnchorMax

UI元素需要自动拉伸时,使用anchorMax、anchorMin + offsetMax、offsetMin来设置UI的位置及大小会比较方便。
其中,anchorMax.x == anchorMin.x,height会自动拉伸,width固定不变。
anchorMax.y == anchorMin.y,width会自动拉伸,height固定不变。

不知不觉已过凌晨1点,先介绍到这里。关于uGUI的更多内容,将在后续博文中继续,敬请期待。

Unity的界面排版: RectTransform的更多相关文章

  1. Unity学习笔记(4) --- Unity的界面排版:初识GUI

    GUI和GUILayout是Unity提供的UIKit.在使用GUI的Controls时都要求设置Rect參数.没办法做到自己主动排版,给适配带来难度.而GUILayout的设计就是为了弥补这个缺陷, ...

  2. Unity编辑器 - 自动排版

    Unity编辑器 - 自动排版 使用花括号提高可读性 //一组横向排列的控件 GUILayout.BeginHorizontal(); { GUILayout.BeginVertical(); { / ...

  3. Android 界面排版的5种方式

    Android布局是应用界面开发的重要一环,在Android中,共有五种布局方式,分别是:FrameLayout(框架布局),LinearLayout (线性布局),AbsoluteLayout(绝对 ...

  4. Unity 屏幕坐标到UGUI RectTransform本地坐标的转换

    public static bool ScreenPointToLocalPointInRectangle(RectTransform rect, Vector2 screenPoint, Camer ...

  5. 界面排版-TableLayout的stretchColumns方法

    1.先把XML內的預設RelativeLayout排版方式清空,在去Layout區拉一個TableLayout的到表單上,XML下會出現下面程式碼       <TableLayout xmln ...

  6. html+css+js整体布局——[防止浏览器扩大,界面排版混乱]

    1,body——>width:100% body { background-color: rgb(238, 238, 238); color: rgb(51, 51, 51); display: ...

  7. unity,set ugui rectTransform anchor by script

    如果想用代码实现与下面面板相同的功能 试验可知改变上面选项下面四个值也随之变化: 所以说明二者是一回事儿. 因此,只要通过代码修改RectTransform的anchorMax和anchorMin成员 ...

  8. [unity]UGUI界面滑动,ScrollRect嵌套滑动

    原因:老板蛋痛,让我去抄皇室战争. 思路:我大概知道ngui(后来改成UGUI的)里面有个ScrollView.于是我就想一个横着的SV加上5个竖的SV不就好了吗. 过程: 于是 但是有个问题就是UI ...

  9. ubuntu14.04安装bodhi桌面系统后,unity启动界面改变,如何还原

    按一下 ctrl + alt + f1 # 出現 tty11. sudo service lxdm stop或sudo /etc/init.d/lxdm stop如果出現錯誤訊息 不理它 繼續2. s ...

随机推荐

  1. 自己动手编译OpenSSL库

    因为工作需要,要实现一个基于SSL的通信程序.之前没有接触过SSL协议通讯,这次学习了一下如何自己编译OpenSSL库. 我使用的环境是Windows 10 + VS2015 1.首先打开VS2015 ...

  2. java通过POI和easypoi实现Excel的导出

    前言 在工作经常会遇到excel导出报表的功能,自己也做过一些,然后在项目里看到同事封装的一个excel导出工具类,着实不错,拿来分享一下.然后,又在网上看到一个使用easypoi实现cxcel导出的 ...

  3. JavaScript中的数据结构及实战系列

    本系列主要是讲解JavaScript中的数据结构及在实际项目中遇到的地方 JavaScript中的数据结构及实战系列(1):队列 JavaScript中的数据结构及实战系列(2):栈

  4. Ajax的text/plain、application/x-www-form-urlencoded和application/json

    Ajax的text/plain.application/x-www-form-urlencoded和application/json HTTP请求中,如果是get请求,那么表单参数以name=valu ...

  5. 在VMware虚拟机中安装Mac OS 操作系统

    1. 安装VMware 我这里是安装VMWARE12.exe,其他的版本我不知道是否可以正常运行,最好大家安装12版本的比较好. 2. 安装 Mac OS X Unlocker for VMware ...

  6. Emacs 编辑verilog 学习日记

       终于开始写博客啦.以前一直打算写.由于工作忙一次次延期了.写博客的好处不必多说. 以前有一些学习心得总是用一个word,或者note记录一些.时间久了都不知道弄哪儿去了.. 从今天开始记录学习中 ...

  7. Pytho并发编程-利用协程实现简单爬虫

    from gevent import monkey;monkey.patch_all() import gevent from urllib.request import urlopen def ge ...

  8. Adobe Audition CC 2017 (10.0)安装教程

    Adobe Audition CC 2017 (10.0)安装教程 注:下载地址在文章末尾 第一步:首先请将电脑的网络断开,很简单:禁用本地连接或者拔掉网线,这样就可以免除登录Creative Clo ...

  9. 美团客户端响应式框架EasyReact开源啦

    前言 EasyReact 是一款基于响应式编程范式的客户端开发框架,开发者可以使用此框架轻松地解决客户端的异步问题. 目前 EasyReact 已在美团和大众点评客户端的部分业务中进行了实践,并且持续 ...

  10. MSTP多生成树的配置

    STP的不足 STP协议虽然能够解决环路问题,但是由于网络拓扑收敛较慢,影响了用户通信质量 而且如果网络中的拓扑结构频繁变化,网络也会随之频繁失去连通性,从而导致用户通信频繁中断 RSTP对STP的改 ...