这个两个东西是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详解的更多相关文章

  1. qml学习笔记(二):可视化元素基类Item详解(上半场anchors等等)

    原博主博客地址:http://blog.csdn.net/qq21497936本文章博客地址:http://blog.csdn.net/qq21497936/article/details/78516 ...

  2. 原生JS:String对象详解

    @import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...

  3. fullPage教程 -- 整屏滚动效果插件 fullpage详解

    1.引用文件 [html] view plain copy print?在CODE上查看代码片派生到我的代码片 <link rel="stylesheet" href=&qu ...

  4. 第三十一节,目标检测算法之 Faster R-CNN算法详解

    Ren, Shaoqing, et al. “Faster R-CNN: Towards real-time object detection with region proposal network ...

  5. JS组件系列——JsPlumb制作流程图及相关效果详解

    上    篇 前言:之前项目里面用到了Web里面的拖拽流程图的技术JsPlumb,其实真不算难,不过项目里面用HTML做的一些类似flash的效果,感觉还不错,在此分享下. Jsplumb官网:htt ...

  6. [转]CNN目标检测(一):Faster RCNN详解

    https://blog.csdn.net/a8039974/article/details/77592389 Faster RCNN github : https://github.com/rbgi ...

  7. 【目标检测】Faster RCNN算法详解

    Ren, Shaoqing, et al. “Faster R-CNN: Towards real-time object detection with region proposal network ...

  8. 转载:Faster-RCNN详解

    原文:http://blog.csdn.net/zy1034092330/article/details/62044941 原文大神有很多经典之作,并且讲解得很透彻,建议前往,这里仅当学习使用. Fa ...

  9. java之Matcher类详解

    在JDK 1.4中,Java增加了对正则表达式的支持. java与正则相关的工具主要在java.util.regex包中:此包中主要有两个类:Pattern.Matcher. Matcher  声明: ...

随机推荐

  1. spring oauth2获取token时WARN:Could not decode JSON for additional information: BaseClientDetails解决办法

    错误描述 简述:oauth_client_details表中additional_information字段默认为null,ClientDetails实体类中类型为Map<String,Obje ...

  2. 打开桌面的Eclipse闪退,打不开

    参考了网上说的方法: .在C:/WINDOWS/system32 系统文件夹中ctrl+F 然后搜索java.exe,如果存在java.exe, javaw.exe etc.全部删除. 2.内存不足, ...

  3. Qt信号参数中使用QVariantList时编译问题

    今天调试代码时遇到一个奇怪的问题,不过一般感觉比较奇怪的问题,最后查到原因时,原因都比较简单! 编译问题 先来看一下qt的编译错误,提示一堆错误: In file included from D:\Q ...

  4. 教你几招,快速创建 MySQL 五百万级数据,愉快的学习各种优化技巧

    我是风筝,公众号「古时的风筝」,一个兼具深度与广度的程序员鼓励师,一个本打算写诗却写起了代码的田园码农! 文章会收录在 JavaNewBee 中,更有 Java 后端知识图谱,从小白到大牛要走的路都在 ...

  5. 小白入门Web前端开发学习一周小结

    说之前还是先说点其他的,简单介绍下自己为何选择web前端开发: 本人之前在一家国企单位从事质检工作,干了3年,工资和待遇还算不错,但由于其工作的流动性导致知识的脱轨以及精神上的空缺,最后还是打算在25 ...

  6. 2020-04-13:怎么在日志里排查错误,该用哪些Linux命令

    能通过less命令打开文件,通过Shift+G到达文件底部,再通过?+关键字的方式来根据关键来搜索信息. 能通过grep的方式查关键字,具体用法是, grep 关键字 文件名,如果要两次在结果里查找的 ...

  7. 解读闭包,这次从ECMAScript词法环境,执行上下文说起

    对于x年经验的前端仔来说,项目也做了好些个了,各个场景也接触过一些.但是假设真的要跟面试官敞开来撕原理,还是有点慌的.看到很多大神都在手撕各种框架原理还是有点羡慕他们的技术实力,羡慕不如行动,先踏踏实 ...

  8. X86汇编——计算斐波那契数列程序(详细注释和流程图说明)

    X86汇编实现斐波那契数列 程序说明: 输入斐波那契数列的项数, 然后依次输出斐波那契数列, 输入的项数小于256且为数字, 计算的项数不能超过2^16次方, 输入失败是 不会回显数字 因为存结果是A ...

  9. 三、HelloWorld

    1.创建Hello.java 文件, 2.输入内容 public class Hello{ //公共类 Hello public static void main(String[] args){ // ...

  10. MySQL查看数据存放位置

    show global variables like "%datadir%";