参考 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. Java扩展Nginx之六:两大filter

    欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 本篇概览 本文是<Java扩展Nginx> ...

  2. [CF 1780B] GCD Partition

    B. GCD Partition 题意 : 给一个长度为n的序列, 并将其分成连续的k块(k > 1), 得到序列b, 使得 \(gcd(b_{1}, b_{2}, b_{3}, ..., b_ ...

  3. java发送http请求(jquery发送http请求,前后端看这一篇文章够了,很完整)

    为什么写这篇博客? 1.目前很多系统使用了微服务架构,那么各个微服务之间进行内部通信一般采用http协议的方式,springcloud中提供了ribbon,feign,openFeign等组件. 但是 ...

  4. 编码技巧 --- 使用dynamic简化反射

    引言 dynamic 是 Framework 4.0 就出现特性,它的出现让 C# 具有了弱语言类型的特性.编译器在编译的时候不再对类型进行检查,默认 dynamic 对象支持开发者想要的任何特性. ...

  5. EasyExcel中使用表头模板示例

    解决方案 在EasyExcel的官方示例中,使用模板导出Excel,其结果仍然还会重新打印表头.不满足使用表头模板的需求.在参考源码后,找到如下解决方案. String templateFileNam ...

  6. 基于weave实现docker跨主机网络通信

    前言 IP: 192.168.0.10 192.168.0.11 系统版本:centos 7 weave版本:2.8.1,下载地址:https://git.io/weave docker版本:18.0 ...

  7. 《深入理解Java虚拟机》读书笔记:垃圾收集算法

    由于垃圾收集算法的实现涉及大量的程序细节,而且各个平台的虚拟机操作内存的方法又各不相同,因此本节不打算过多地讨论算法的实现,只是介绍几种算法的思想及其发展过程. 垃圾收集算法概要 1. 标记-清除算法 ...

  8. Docker从入门到部署项目

    Docker概念 Docker是一个开源的应用容器引擎,它是基于Go语言并遵从Apache2.0协议开源.Docker可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流 ...

  9. 角度新奇!第一次看到这样使用MyBatis的,看得我一愣一愣的。

    你好呀,我是歪歪. 这期给大家分享一个读者给我分享的一个关于 MyBatis 的"编程小技巧",说真的,这骚操作,直接把我看得一愣一愣的. 我更情愿叫它:坑你没商量之埋雷大法. D ...

  10. [译]2023年 Web Coponent 现状

    本文为翻译 原文地址:2023 State of Web Components: Today's standards and a glimpse into the future. 最近,我写了关于如何 ...