Anchors Piovt详解
这个两个东西是RectTransform里面的两个属性,也是UGUI做UI自适应的重要工具,之前做的的时候,都只是调出效果即可,并没有深究其中的原理,现在决定来补上这个漏洞。
首选我们来看看Anchors的行为是怎么来控制的。
1.在Inspector面板中,控制Anchors的位置的值有四个,如图:


而Anchor是有四瓣,根据实验结果,
Xmin 控制 点1、 2的x轴的位置 Xmax控制 点3、 4的x轴的位置
Ymin控制 点1、 3的Y轴的位置 Ymax控制 点2、 4的Y轴的位置
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
在Inspector面板中,根据Anchors的值的不同,RectTransform会表现出不同的值,我们现在具体讨论这些情况。
1. 当Anchors的四个点重合时。(也就是 Xmin =Xmax,Ymin =Ymax)
a.子物体相对于父物体的位置,对应在inspector面板中的值如下2图:


通过上图可以看到,子物体的位置其实是由子物体的Pivot位置相较于Anchors点的偏移量确定的。该图中的PosX = 322,PosY = -170,刚好与左图中虚线的偏移量一致。
b.在父物体变换形状时,子物体的形状变化,通过下面的动图可以清晰的明白原理(拿来主义了一波):
可以看到,其实子物体形状缩放,其实是子物体的四个顶点的距离Anchor 点的四个点的间距比例保持一致。也就是说,
如果Anchor的四个点重合在一起,那么无论父物体形状如何形变,子物体的形状都不会被变形拉伸,并且会保持与Anchor点的偏移量不变。


2. 当Anchors的四个点不重合时:
2.1当Xmin !=Xmax ,Ymin =Ymax,也就是左右分开时:


可以看到,inspector面板中的参数已经变了,它们具体的含义如上左图:
Left:子物体左边 距 左Anchor点 的偏移量 Right:子物体右边 距 右Anchor点 的偏移量
Pos Y:子物体Pivot点 距离 Anchor点 的 Y轴 偏移量。 Height : 子物体的高度值。
处于这种情况时:
1.子物体的 位置 永远 与 Anchor的位置保 持一定距离 不变。
2.子物体的 高度 不会被拉伸。
3.子物体的 宽度 会随着父物体的宽度拉伸而拉伸。
动图如下:


2.2当Ymin !=Ymax,Xmin =Xmax,也就是上下分开时:
这个时候的情况与2.1的情况类似,只不过是由左右变为了上下而已,具体参数如下:


同样的,在这种情况下,
1.子物体的 位置 永远 与 Anchor的位置保 持一定距离 不变。
2.子物体的 宽度 不会被拉伸。
3.子物体的 高度 会随着 父物体的高度 拉伸而拉伸。
2.3当Ymin !=Ymax,Xmin !=Xmax,也就是四个点全部分开时:


这个时候,参数变成了:
Left:子物体 左边 距离 左边 anchor点的距离 Right:子物体 右边 距离 右边anchor点的距离
Top:子物体 上边 距离 上边 anchor点的距离 Bottom:子物体 下边 距离 下边 anchor点的距离
这个时候,如果父物体发生了形变:
1.子物体的 pivot 位置 会与一个 虚拟的anchor点 的距离保持不变。
2.子物体宽度 会随父物体宽度变化而变化。
3. 子物体的高度 会随父物体高度变化而变化。
最后:
pivot 可以设置任意值,不过(0,0)为左下角点,(1,1)为右上角点
anchor的取值无论x,y,都是[0,1]。
Anchors Piovt详解的更多相关文章
- qml学习笔记(二):可视化元素基类Item详解(上半场anchors等等)
原博主博客地址:http://blog.csdn.net/qq21497936本文章博客地址:http://blog.csdn.net/qq21497936/article/details/78516 ...
- 原生JS:String对象详解
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...
- fullPage教程 -- 整屏滚动效果插件 fullpage详解
1.引用文件 [html] view plain copy print?在CODE上查看代码片派生到我的代码片 <link rel="stylesheet" href=&qu ...
- 第三十一节,目标检测算法之 Faster R-CNN算法详解
Ren, Shaoqing, et al. “Faster R-CNN: Towards real-time object detection with region proposal network ...
- JS组件系列——JsPlumb制作流程图及相关效果详解
上 篇 前言:之前项目里面用到了Web里面的拖拽流程图的技术JsPlumb,其实真不算难,不过项目里面用HTML做的一些类似flash的效果,感觉还不错,在此分享下. Jsplumb官网:htt ...
- [转]CNN目标检测(一):Faster RCNN详解
https://blog.csdn.net/a8039974/article/details/77592389 Faster RCNN github : https://github.com/rbgi ...
- 【目标检测】Faster RCNN算法详解
Ren, Shaoqing, et al. “Faster R-CNN: Towards real-time object detection with region proposal network ...
- 转载:Faster-RCNN详解
原文:http://blog.csdn.net/zy1034092330/article/details/62044941 原文大神有很多经典之作,并且讲解得很透彻,建议前往,这里仅当学习使用. Fa ...
- java之Matcher类详解
在JDK 1.4中,Java增加了对正则表达式的支持. java与正则相关的工具主要在java.util.regex包中:此包中主要有两个类:Pattern.Matcher. Matcher 声明: ...
随机推荐
- 树形DP 学习笔记(树形DP、树的直径、树的重心)
前言:寒假讲过树形DP,这次再复习一下. -------------- 基本的树形DP 实现形式 树形DP的主要实现形式是$dfs$.这是因为树的特殊结构决定的——只有确定了儿子,才能决定父亲.划分阶 ...
- 自定义 Mybatis 框架
分析流程 1. 引入dom4j <dependencies> <!--<dependency> <groupId>org.mybatis</groupI ...
- Android——对话框的全部内容。(课堂总结)
前面的总结是写过对话框的,但是那只是冰山一角,简单的创建和使用罢了. 今天具体讲下AlertDialog. 首先对话框不需要在布局里写,在活动里new出来的. AlertDialog.Builder ...
- Elasticsearch从入门到放弃:瞎说Mapping
前面我们聊了 Elasticsearch 的索引.搜索和分词器,今天再来聊另一个基础内容-- Mapping. Mapping 在 Elasticsearch 中的地位相当于关系型数据库中的 sche ...
- 关键字Run Keyword If 如何写多个条件语句、如何在一个条件下执行多个关键字
Run Keyword If 关键字给出的示例是: 但是,这往往不能满足我们实际需要,比如,我们需要同时判断多个条件是否成立,或者在条件成立时我们想要执行多个关键字,虽然可以进行封装再调用,但是比较麻 ...
- Python使用socketServer包搭建简易服务器过程详解
官方提供了socketserver包去方便我们快速的搭建一个服务器框架. 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手.很多已经做案例的 ...
- Spring Boot 集成 Elasticsearch 实战
最近有读者问我能不能写下如何使用 Spring Boot 开发 Elasticsearch(以下简称 ES) 相关应用,今天就讲解下如何使用 Spring Boot 结合 ES. 可以在 ES 官方文 ...
- 小白学习Python之路---py文件转换成exe可执行文件
一.背景 今天闲着无事,写了一个小小的Python脚本程序,然后给同学炫耀的时候,发现每次都得拉着其他人过来看着自己的电脑屏幕,感觉不是很爽,然后我想着网上肯定有关于Python脚本转换成可执行文件的 ...
- Java Redis系列3(Jedis的使用+jedis连接池技术)
Jedis的使用 什么是Jedis? 一款Java操作redis数据库的工具 使用步骤 1.下载redis所需的java包 2.使用步骤 import org.junit.Test; public c ...
- 2020-07-24:聊一下zookeeper的同步算法。
福哥答案2020-07-24: 同步算法基于 ZAB 协议,一种快速 Paxos 算法. 快速Paxos算法Paxos算法可能出现死循环,就是在两个Proposer总是在交替prepare.并且,Pa ...