参考 https://zhuanlan.zhihu.com/p/119442308

在已经有结果的情况下,先捋一下unity对相关字段的注释就能得出很多公式

(rectMinPos表示左下角在父节点坐标系中的位置,其他以"Pos"结尾的字段同理)

pivot: The normalized position in this RectTransform that it rotates around.
pivot: 旋转中心点的归一化位置(使用自己的宽高归一化)
pivotPos = rectMinPos + rect.size * pivot localPosition: Position of the transform relative to the parent transform
localPosition: 相对于父节点的位置
对于一个RectTransform自己,可以判断localPosition2D和pivotPos就是同一个点
localPosition2D = pivotPos rect.min: The position of the minimum corner of the rectangle.
rect.min: 左下角的位置(相对于谁?应该是中心点pivot坐标)
rect.max: 右上角的位置
rectMinPos = rect.min + pivotPos
rectMaxPos = rect.max + pivotPos anchorMin: The normalized position in the parent RectTransform that the lower left corner is anchored to.
anchorMin: 左下角相对于父节点(左下角)的归一化位置(使用父节点宽高归一化)
anchorMax: 右上角相对于父节点的归一化位置
anchorMin = (anchorMinPos - parentRect.min) / parentRect.size
anchorMax = (anchorMaxPos - parentRect.min) / parentRect.size
anchorMinPos = parentRect.min + anchorMin * parentRect.size
anchorMaxPos = parentRect.min + anchorMax * parentRect.size anchoredPosition: The position of the pivot of this RectTransform relative to the anchor reference point.
anchoredPosition: 中心点相对于"the anchor reference point"的位
anchoredPosition = pivotPos - (anchorMinPos + (anchorMaxPos - anchorMinPos) * pivot) offsetMin: The offset of the lower left corner of the rectangle relative to the lower left anchor
offsetMin: 左下角相对于左下锚点的偏移
offsetMax: 右上角相对于右上锚点的偏移
offsetMin = rectMinPos - anchorMinPos
offsetMax = rectMaxPos - anchorMaxPos sizeDelta: The size of this RectTransform relative to the distances between the anchors.
sizeDelta: 宽高与锚点之间宽高的差值
sizeDelta = rect.size - (anchorMaxPos - anchorMinPos)
= (rectMaxPos - rectMinPos) - (anchorMaxPos - anchorMinPos)
= (rectMaxPos - anchorMaxPos) - (rectMinPos - anchorMinPos)
= offsetMax - offsetMin

1. 从localPosition到anchoredPosition


// 计算自身的anchoredPosition(直接从RectTransform获取即可,这里只演示推导流程,没有实用性)
public static Vector2 GetAnchoredPosition(RectTransform transform)
{
/* 计算推导
anchoredPosition = pivotPos - (anchorMinPos + (anchorMaxPos - anchorMinPos) * pivot)
到这里其实就已经可以算了, 只是步骤多一点, 继续化简以达到参考文章的公式
代入 sizeDelta = rect.size - (anchorMaxPos - anchorMinPos)
anchoredPosition = pivotPos - anchorMinPos - (rect.size - sizeDelta) * pivot
代入 pivotPos = localPosition2D = rectMinPos + rect.size * pivot
anchoredPosition = rectMinPos + rect.size * pivot - anchorMinPos - rect.size * pivot + sizeDelta * pivot
= rectMinPos - anchorMinPos + sizeDelta * pivot
代入 offsetMin = rectMinPos - anchorMinPos
anchoredPosition = offsetMin + sizeDelta * pivot
*/ if (transform == null || transform.Equals(null)) return Vector2.zero;
return transform.offsetMin + sizeDelta * pivot;
} public static Vector2 LocalToAnchoredPosition(RectTransform transform, Vector2 localPosition2D)
{
if (transform == null || transform.Equals(null)) return Vector2.zero;
RectTransform parent = transform.parent?.GetComponent<RectTransform>();
if (parent == null) return Vector2.zero; // 在传入localPosition2D的情况下, 就不能使用刚才化简的结果了, 使用最早一版的公式
Rect parentRect = parent.rect;
Vector2 pivot = transform.pivot;
Vector2 anchorMin = transform.anchorMin;
Vector2 anchorMax = transform.anchorMax;
Vector2 anchorMinPos = parentRect.min + anchorMin * parentRect.size;
Vector2 anchorMaxPos = parentRect.min + anchorMax * parentRect.size; return localPosition2D - (anchorMinPos + (anchorMaxPos - anchorMinPos) * pivot);
}

2. 从anchoredPosition到localPosition

// 刚才的函数反向一下即可
public static Vector2 AnchoredToLocalPosition(RectTransform transform, Vector2 anchoredPosition)
{
if (transform == null || transform.Equals(null)) return Vector2.zero;
RectTransform parent = transform.parent?.GetComponent<RectTransform>();
if (parent == null) return Vector2.zero; Rect parentRect = parent.rect;
Vector2 pivot = transform.pivot;
Vector2 anchorMin = transform.anchorMin;
Vector2 anchorMax = transform.anchorMax;
Vector2 anchorMinPos = parentRect.min + anchorMin * parentRect.size;
Vector2 anchorMaxPos = parentRect.min + anchorMax * parentRect.size; return anchoredPosition + (anchorMinPos + (anchorMaxPos - anchorMinPos) * pivot);
}

Unity anchoredPosition转localPosition的更多相关文章

  1. Unity position和localposition

    1. position是根据世界原点为中心 2. localPosition是根据父节点为中心,如果没有父节点,localpositon和position是没有区别的 3.选中一个物体左上角Globa ...

  2. Unity的UGUI在SetParent后修改UI的localposition问题

    正常情况下,UGUI设置UI的localposition可以直接赋值 UIxxx.rectTransform.localPosition = ] / 2f, , ); 运行后在Unity的Inspec ...

  3. # Unity 游戏框架搭建 2019 (十六、十七) localPosition 简化与Transform 重置

    在上一篇我们收集了一个 屏幕分辨率检测的一个小工具.今天呢再往下接着探索. 问题 我们今天在接着探索.不管是写 UI 还是写 GamePlay,多多少少都需要操作 Transform. 而在笔者刚接触 ...

  4. RectTransform的localPosition与anchoredPosition(3D)的区别

    RectTransform继承自Transform,用于描述矩形的坐标(Position),尺寸(Size),锚点(anchor)和中心点(pivot)等信息,每个2D布局下的元素都会自动生成该组件. ...

  5. unity, surface shader access world position and localposition

    一,surface shader中访问worldposition 在surface shader中访问世界坐标,只需在Input结构体中声明float3 worldPos即可,如下:  struct  ...

  6. Unity 坐标 转换 详解 World世界坐标 Screen屏幕坐标 View视口坐标 GUI坐标 NGUI坐标 localPosition相对父级坐标

    在制作游戏中我们经常会遇到这样一个需求: 在人物模型的上面显示 名字.称号 一类的文字或者图片 如下图 人物模型属于是Camera1   UI Title信息属于NGUI Camera2 如下图 这时 ...

  7. unity, change parent and keep localPosition or worlPosition

    node.parent=othernode等价于node.setParent(othernode,true),是保持世界坐标不变. node.setParent(othernode,false)则可以 ...

  8. Unity ugui屏幕适配与世界坐标到ugui屏幕坐标的转换

    我们知道,如今的移动端设备分辨率五花八门,而开发过程中往往只取一种分辨率作为设计参考,例如采用1920*1080分辨率作为参考分辨率. 选定了一种参考分辨率后,美术设计人员就会固定以这样的分辨率来设计 ...

  9. Unity ugui拖动控件(地图模式与物件模式)

    拖动在游戏中使用频繁,例如将装备拖动到指定的快捷栏,或者大地图中拖动以查看局部信息等. Unity的EventSystems中可以直接继承几个接口来实现拖动功能,如下: namespace Unity ...

  10. Unity ugui Anchor锚点自动适配画布中的相对位置

    本随笔参考了以下博客,在此基础上进行优化和改进: https://blog.csdn.net/qq_39640124/article/details/88284191 ugui中的Anchor预设如下 ...

随机推荐

  1. 【Python】万字长文,Locust 性能测试指北(上)

    Locust Locust 是比较常见的性能测试工具,底层基于 gevent.官方介绍 它是一款易于使用.可编写脚本且可扩展的性能测试工具,可以让我们使用常规 Python 代码定义用户的行为,而不必 ...

  2. 基于ChatGPT上线《你说我猜》小游戏

    摘要 AIGC.GPT.休闲小游戏三者可以怎么结合? AIGC.GPT与小游戏的结合为游戏体验带来了新的可能性.AIGC(Artificial Intelligence Game Content)作为 ...

  3. 超详细整合SSM框架--(Spring + Spring MVC + MyBatis)

    超详细整合SSM框架--(Spring + Spring MVC + MyBatis) 阅读该文章之前首先要清楚Spring框架,SpringMVC框架,Mybatis框架. SSM框架,是Sprin ...

  4. PTA 21级数据结构与算法实验5—树和二叉树

    目录 7-1 还原二叉树 7-2 朋友圈 7-3 修理牧场 7-4 玩转二叉树 7-5 根据后序和中序遍历输出先序遍历 7-6 完全二叉树的层序遍历 7-7 列出叶结点 7-8 部落 7-9 建立与遍 ...

  5. zabbix 主动模式下报文分析

    获取监控项列表 客户端发起请求 3次握手之后,请求监控项列表: {"request":"active checks","host":&quo ...

  6. 使用netdata 监控Linux 主机

    在linux主机上,直接使用下面的命令创建容器即可 docker run -d --name=netdata \ -p 19999:19999 \ -v netdataconfig:/etc/netd ...

  7. Linux 文件系统的设计

    一 硬盘的最小存储单元是扇区,扇区大小为512B 文件系统将硬盘划分为固定大小的块(block),最常见的块大小为4KB 块是文件系统读写硬盘的最小单位 二 文件系统设计面临的基本问题: 用户怎么找到 ...

  8. WebStorm: 配置React中useState自动补齐功能

    配置如下 模板文本如下所示 const [$STATE$, $SET_STATE$] = useState($INITAL_STATE$) 编辑变量 SET_STATE文本如下所示 concat(&q ...

  9. 一些重要的sql命令

    SELECT - 从数据库中提取数据 UPDATE - 更新数据库中的数据 DELETE - 从数据库中删除数据 INSERT INTO - 向数据库中插入新数据 CREATE DATABASE - ...

  10. 在不修改代码情况下解决 Chrome 浏览器跨域

    前言: 在前后台分离的项目,跨域是经常遇到的问题了.是实际解决方案中,大部分采用服务端配置,而如果只是调试,可以通过配置 Chrome 浏览器实现跨域,以下以 NodeJs 服务为例. 开始: 1. ...