【Unity3D】UGUI的anchoredPosition锚点坐标

本文直接以实战去理解锚点坐标,围绕着将一个UI移动到另一个UI位置的需求进行说明。

(anchoredPosition)UI锚点坐标,它是UI物体的中心点坐标,以UI物体锚点为中心的坐标系得来,UI锚点坐标受锚点(Anchors Min、Max)和 中心点Pivot影响。

针对锚点坐标详细说明

可直接查看RectTransform组件的Pos X和Pos Y得知锚点情况,但是只有这9种锚点分布才允许直接查看。

 其他7种锚点布局情况则是

剩下3个锚点布局情况对锚点的影响一样,都是以父物体的中心点为锚点计算锚点坐标。

上面3个都是和下面这个锚点布局一样,都是能直接拿到PosX PosY是(-133,62)的

实战例子

Debug.Log("btn2.anchoredPosition:" + btn2.anchoredPosition);
Debug.Log("hand.anchoredPosition:" + hand.anchoredPosition);
//不能正常移动,除非2个物体都在相同的父节点以及锚点相同
hand.anchoredPosition = btn2.anchoredPosition;

 需求是将hand物体移动到btn2物体上,如上图实战会失败。

原因:锚点不相同(虽然父物体一样)
解决:保证锚点相同、父物体相同

//1.保证父节点相同
hand.parent = btn2.parent;
//2.保证锚点相同
hand.anchorMin = btn2.anchorMin;
hand.anchorMax = btn2.anchorMax;
//能正常移动
hand.anchoredPosition = btn2.anchoredPosition;

缺点:当存在父物体是一个布局组件时(或父物体需操控子物体位置时),hand的位置会被控制无法正常设置到btn2位置。

当我们继续使用【保证锚点相同、父物体相同】来移动hand物体时,会因为布局组件而改变了hand物体位置。

解决思路1:给hand物体加LayoutElement组件忽略布局组件的影响。

解决思路2:不进行hand物体转到btn1物体的父物体下,hand物体始终在Canvas根节点下,然后去获取btn1物体在Canvas根节点下的锚点坐标(反过来理解就是逻辑上将btn1物体放到了Canvas根节点然后取锚点坐标,并且锚点坐标是相对Canvas坐标系中心点的坐标)

//1.关键点btn1.position已经正确赋值后才进行如下
//比如 btn1在布局组件之下,需要先进行一次强制刷新来保证btn1位置正常
//LayoutRebuilder.ForceRebuildLayoutImmediate(layoutRectTransform);

//2.保证hand物体的锚点布局是以父物体中心点为坐标系(因为下面转锚点的空间是以父物体中心点的)
hand.anchorMin = new Vector2(0.5f, 0.5f);
hand.anchorMax = new Vector2(0.5f, 0.5f);

//3.将btn1世界坐标转屏幕坐标
Vector2 screenPos = RectTransformUtility.WorldToScreenPoint(Camera.main, btn1.position);

//4.屏幕坐标转相对于localRect(即Canvas)中心点的锚点坐标
Vector2 localPos = Vector2.zero;
RectTransform handParentRectTransform = hand.parent.GetComponent<RectTransform>();
RectTransformUtility.ScreenPointToLocalPointInRectangle(handParentRectTransform, screenPos, Camera.main, out localPos);

hand.anchoredPosition = localPos;

这步操作很关键:LayoutRebuilder.ForceRebuildLayoutImmediate(layoutRectTransform);
需要将所有父节点的布局组件强制刷新一遍来保证UI的世界坐标正常

public void ForceRebuildLayoutImmediate(Transform transform)
{
    LayoutGroup[] layoutGroups = transform.GetComponentsInParent<LayoutGroup>();
    if (layoutGroups != null && layoutGroups.Length > 0)
    {
        foreach (var v in layoutGroups)
        {
            LayoutRebuilder.ForceRebuildLayoutImmediate(v.GetComponent<RectTransform>());
        }
    }
}

其次就是RectTransformUtility.ScreenPointToLocalPointInRectangle是将屏幕坐标转到以第一个参数RectTransform为中心的锚点坐标,实战则是获取到btn1的屏幕坐标后将其转到以hand物体的父物体(Canvas) 为中心的锚点坐标,然后我们就能直接用该坐标赋值给hand物体,实现将hand物体移动到btn1物体位置效果。

题外:

世界坐标,能实现需求将hand移动到btn1的位置,但如果要加偏移量之类的世界坐标不直观理解

//此前还需保证布局组件相关的刷新,与锚点坐标情况是一样的

hand.position = btn1.position;

注意事项

为什么UGUI获取布局组件下的UI坐标(无论是锚点坐标还是世界坐标等等)都可能出现非常大的误差,甚至说是完全不正确。
因为布局组件有延迟性, 你必须使用LayoutRebuilder.ForceRebuildLayoutImmediate(layoutRectTransform); 在获取坐标之前进行强制刷新布局组件,保证布局组件下的UI坐标是正常的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/967577.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Hadoop】大数据权限管理工具Ranger2.1.0编译

目录 ​编辑一、下载 ranger源码并编译 二、报错信息 报错1 报错2 报错3 报错4 一、下载 ranger源码并编译 ranger官网 https://ranger.apache.org/download.html 由于Ranger不提供二进制安装包&#xff0c;故需要maven编译。安装其它依赖&#xff1a; yum install gcc …

C++20导出模块及使用

1.模块声明 .ixx文件为导入模块文件 math_operations.ixx export module math_operations;//模块导出 //导出命名空间 export namespace math_ {//导出命名空间中函数int add(int a, int b);int sub(int a, int b);int mul(int a, int b);int div(int a, int b); } .cppm文件…

使用 mkcert 本地部署启动了 TLS/SSL 加密通讯的 MongoDB 副本集和分片集群

MongoDB 是支持客户端与 MongoDB 服务器之间启用 TLS/SSL 进行加密通讯的, 对于 MongoDB 副本集和分片集群内部的通讯, 也可以开启 TLS/SSL 认证. 本文会使用 mkcert 创建 TLS/SSL 证书, 基于创建的证书, 介绍 MongoDB 副本集、分片集群中启动 TLS/SSL 通讯的方法. 我们将会在…

2、k8s的cni网络插件和基本操作命令

kube-prxoy属于节点组件&#xff0c;网络代理&#xff0c;实现服务的自动发现和负载均衡。 k8s的内部网络模式 1、pod内的容器于容器之间的通信。 2、一个节点上的pod之间的通信&#xff0c;docker0网桥直接通信。 3、不同节点上的pod之间的通信&#xff1a; 通过物理网卡的…

如何在RTACAR中配置IP多播(IP Multicast)

一、什么是IP多播 IP多播&#xff08;IP Multicast&#xff09;是一种允许数据包从单一源地址发送到多个目标地址的技术&#xff0c;是一种高效的数据传输方式。 多播地址是专门用于多播通信的IP地址&#xff0c;范围从 224.0.0.0到239.255.255.255 与单播IP地址不同&#x…

JavaEE架构

一.架构选型 1.VM架构 VM架构通常指的是虚拟机&#xff08;Virtual Machine&#xff09;的架构。虚拟机是一种软件实现的计算机系统&#xff0c;它模拟了物理计算机的功能&#xff0c;允许在单一物理硬件上运行多个操作系统实例。虚拟机架构主要包括以下几个关键组件&#xff…

车载测试工具 --- CANoe VH6501 进行Not Acknowledge (NAck) 测试

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 简单,单纯,喜欢独处,独来独往,不易合同频过着接地气的生活,除了生存温饱问题之外,没有什么过多的欲望,表面看起来很高冷,内心热情,如果你身…

第40天:Web开发-JS应用VueJS框架Vite构建启动打包渲染XSS源码泄露代码审计

#知识点 1、安全开发-VueJS-搭建启动&打包安全 2、安全开发-VueJS-源码泄漏&代码审计 一、Vue搭建创建项目启动项目 1、Vue 框架搭建->基于nodejs搭建&#xff0c;安装nodejs即可 参考&#xff1a;https://cn.vuejs.org/ 已安装18.3或更高版本的Node.js 2、Vue 创建…

Axure原型图怎么通过链接共享

一、进入Axure 二、点击共享 三、弹出下面弹框&#xff0c;点击发布就可以了 发布成功后&#xff0c;会展示链接&#xff0c;复制即可共享给他人 四、发布失败可能的原因 Axure未更新&#xff0c;首页菜单栏点击帮助选择Axure更新&#xff0c;完成更新重复以上步骤即可

DeepSeek本地化部署

DeepSeek本地化部署 本教程为一键式部署&#xff0c;适合于mac、ubuntu、windows。【开源地址】 环境要求 nodejs > 18Python > 3.10.12 步骤一&#xff1a;安装ollama客户端 官网直接安装&#xff0c;ollama官网。安装完成后使用命令&#xff1a;ollama -h&#xf…

单片机学习笔记——入门51单片机

一、单片机基础介绍 1.何为单片机 单片机&#xff0c;英文Micro Controller Unit&#xff0c;简称MCU 。内部集成了中央处理器CPU、随机存储器ROM、只读存储器RAM、定时器/计算器、中断系统和IO口等一系列电脑的常用硬件功能 单片机的任务是信息采集&#xff08;依靠传感器&a…

DeepSeek-R1相关论文解读

另&#xff1a;数学推理论文篇&#xff1a;DeepSeekMath 一、DeepSeek-R1-Zero和DeepSeek R1区别 都使用了RL强化学习中的GROP&#xff0c;但是R1还使用了SFT&#xff0c;进行了多阶段训练。 1. 什么是SFT&#xff1f; SFT是给模型一些正确例子&#xff1a;情况1 answer&…

【AIGC】语言模型的发展历程:从统计方法到大规模预训练模型的演化

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: AIGC | ChatGPT 文章目录 &#x1f4af;前言&#x1f4af;语言模型的发展历程&#xff1a;从统计方法到大规模预训练模型的演化1 统计语言模型&#xff08;Statistical Language Model, SLM&#xff09;&#xff1a;统…

ArcGIS Pro批量创建离线服务sd包

背景&#xff1a; 主要针对一个工程内有多个地图框项&#xff1a; 处理方法&#xff1a;通过Python脚本处理打包。 运行环境 在Pro的Python环境中去运行编写的Python脚本。 Python 脚本参考 import arcpy import os# Set output file names outdir r"d:\data\out&…

天津三石峰科技——汽车生产厂的设备振动检测项目案例

汽车产线有很多传动设备需要长期在线运行&#xff0c;会出现老化、疲劳、磨损等 问题&#xff0c;为了避免意外停机造成损失&#xff0c;需要加装一些健康监测设备&#xff0c;监测设备运 行状态。天津三石峰科技采用 12 通道振动信号采集卡&#xff08;下图 1&#xff09;对…

【Linux】深入理解linux权限

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;Linux 目录 前言 一、权限是什么 二、用户和身份角色 三、文件属性 1. 文件属性表示 2. 文件类型 3. 文件的权限属性 四、修改文件的权限属性和角色 1. …

三次握手,四次挥手,服务器模型(多进程并发,线程),基于套接字的UDP通信

三次握手&#xff1a; 第一次握手&#xff1a;客户端向服务器发送SYN待确认数据x, 客户端进入SYN_SEND状态​ 第二次握手&#xff1a;服务器向客户端回传一条ACK应答数据x1, 同时发送一条SYN待确认数据y&#xff0c;服务器进入SYN_RECV状态​ 第三次握手&#xff1a;客户端向服…

PostgreSQL的学习心得和知识总结(一百六十七)|深入理解PostgreSQL数据库之静态语法检查工具PgSanity的使用和实现

目录结构 注:提前言明 本文借鉴了以下博主、书籍或网站的内容,其列表如下: 1、参考书籍:《PostgreSQL数据库内核分析》 2、参考书籍:《数据库事务处理的艺术:事务管理与并发控制》 3、PostgreSQL数据库仓库链接,点击前往 4、日本著名PostgreSQL数据库专家 铃木启修 网站…

【数据结构】双向链表(真正的零基础)

链表是一种物理存储单元上非连续、非顺序的存储结构。数据元素的逻辑顺序是通过指针的链接来实现的&#xff01;在上篇我们学习了单向链表&#xff0c;而单向链表虽然空间利用率高&#xff0c;插入和删除也只需改变指针就可以达到&#xff01;但是我们在每次查找、删除、访问..…

Docker 之mysql从头开始——Docker下mysql安装、启动、配置、进入容器执行(查询)sql

一、Docker 之mysql安装配置 步骤一&#xff1a;拉取镜像 1. 查看是否包含已安装的mysql。 docker images | grep mysql 2. 如上图所示&#xff0c;我们有mysql镜像&#xff0c;所以不必对mysql镜像进行拉取&#xff0c;如若没有上图中的惊喜&#xff0c;使用如下命令进行拉取…