Unity anchoredPosition转localPosition
参考 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的更多相关文章
- Unity position和localposition
1. position是根据世界原点为中心 2. localPosition是根据父节点为中心,如果没有父节点,localpositon和position是没有区别的 3.选中一个物体左上角Globa ...
- Unity的UGUI在SetParent后修改UI的localposition问题
正常情况下,UGUI设置UI的localposition可以直接赋值 UIxxx.rectTransform.localPosition = ] / 2f, , ); 运行后在Unity的Inspec ...
- # Unity 游戏框架搭建 2019 (十六、十七) localPosition 简化与Transform 重置
在上一篇我们收集了一个 屏幕分辨率检测的一个小工具.今天呢再往下接着探索. 问题 我们今天在接着探索.不管是写 UI 还是写 GamePlay,多多少少都需要操作 Transform. 而在笔者刚接触 ...
- RectTransform的localPosition与anchoredPosition(3D)的区别
RectTransform继承自Transform,用于描述矩形的坐标(Position),尺寸(Size),锚点(anchor)和中心点(pivot)等信息,每个2D布局下的元素都会自动生成该组件. ...
- unity, surface shader access world position and localposition
一,surface shader中访问worldposition 在surface shader中访问世界坐标,只需在Input结构体中声明float3 worldPos即可,如下: struct ...
- Unity 坐标 转换 详解 World世界坐标 Screen屏幕坐标 View视口坐标 GUI坐标 NGUI坐标 localPosition相对父级坐标
在制作游戏中我们经常会遇到这样一个需求: 在人物模型的上面显示 名字.称号 一类的文字或者图片 如下图 人物模型属于是Camera1 UI Title信息属于NGUI Camera2 如下图 这时 ...
- unity, change parent and keep localPosition or worlPosition
node.parent=othernode等价于node.setParent(othernode,true),是保持世界坐标不变. node.setParent(othernode,false)则可以 ...
- Unity ugui屏幕适配与世界坐标到ugui屏幕坐标的转换
我们知道,如今的移动端设备分辨率五花八门,而开发过程中往往只取一种分辨率作为设计参考,例如采用1920*1080分辨率作为参考分辨率. 选定了一种参考分辨率后,美术设计人员就会固定以这样的分辨率来设计 ...
- Unity ugui拖动控件(地图模式与物件模式)
拖动在游戏中使用频繁,例如将装备拖动到指定的快捷栏,或者大地图中拖动以查看局部信息等. Unity的EventSystems中可以直接继承几个接口来实现拖动功能,如下: namespace Unity ...
- Unity ugui Anchor锚点自动适配画布中的相对位置
本随笔参考了以下博客,在此基础上进行优化和改进: https://blog.csdn.net/qq_39640124/article/details/88284191 ugui中的Anchor预设如下 ...
随机推荐
- Python中 sys.argv[]用法详解
sys.argv[0]表示代码本身文件路径. sys.argv[]是一个从程序外部获取参数的桥梁,从外部取得的参数可以是多个,所以获得的是一个列表(list),也就是说sys.argv其实可以看作是一 ...
- CentOS 8搭建Kubernetes-k8s集群-1.18.5
目录 环境配置 服务器信息 软件版本 环境正确性 端口正常开放 kube-master节点端口 kube-node节点端口 配置主机互信 配置hosts映射 配置ssh密钥 禁用swap 关闭SELi ...
- Struts2 小知识点
配置struts.xml文件,选择开发模式 在实际应用开发或者是产品部署的时候,对应着两种模式: 开发模式(devMode):此时 DevMode=ture: 产品模式(proMode):此时 Dev ...
- EasyExcel · 写excel
原文地址 通用数据生成 后面不会重复写 private List<DemoData> data() { List<DemoData> list = ListUtils.newA ...
- volatile是如何保证有序性的?
为什么需要保证有序性? 有如下代码,在int i = a;执行了的情况下,i的值最终会为几? public class NoVolatileExample { int a = 0; boolean f ...
- Linux 性能监控与分析相关的软件包
检测系统进程和资源使用情况 -- procps-ng procps-ng是一个用于检测Linux系统进程和资源使用情况的系统工具,它是procps的一个重写版本.它提供了多种用于检测Linux系统中进 ...
- .net通用RSA加密工具类
目前最流行的加密算法莫过于RSA了,以下是我们.net/.net core C#生成环境用的RSA加密工具类,在此分享给大家. using System; using System.IO; using ...
- redis 中的 set
set是String中的无序集合 底层是 是 value为null 的hash表 时间复杂化是o(1): sadd k1 v1 v2 v3 set中添加数据 smembers k1 取出set ...
- 去中心化组件共享方案 —— Webpack Module Federation(模块联邦)
在大型应用中, 我们可能会对其进行拆分,分成容器.主应用和多个子应用,使拆分后的应用独立开发与部署,更加容易维护.但无论是微应用.公共模块应用,都需要放到容器中才能使用. 如果多个应用之间希望资源共享 ...
- [clickhouse]同步MySQL
前言 clickhouse的查询速度非常快,而且兼容大部分MySQL的sql语法,因此一般将clickhouse作为MySQL的读库. 本文提供两种clickhouse同步MySQL的方式 click ...