Canvas 坐标系变换

2 篇文章 0 订阅

PDF的坐标系原点是在页面的左下角

  • 从左至右为X轴的正方向
  • 从下至上为Y轴的正方向

在这里插入图片描述

HTML Canvas 与 OFD的坐标原点是在左上角

  • 从左至右为X轴的正方向
  • 从上至下为Y轴的正方向

在这里插入图片描述

为了便于这里介绍如何从左上角坐标通过坐标变换到左下角坐标

这里列出两种变换方式:

方式1

  1. 将坐标上下翻转。
  2. 平移坐标到页面的左下角位置,也就是负的页面高度。
ctx.scale(1, -1);
ctx.translate(0, -height);

在这里插入图片描述

方式 2

  1. 旋转坐标180°
  2. 坐标翻转坐标系。
  3. 平移到左下角,也就是负的高度。
ctx.rotate(Math.PI)
ctx.scale(-1, 1);
ctx.translate(0,-height);

在这里插入图片描述

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Unity3D中,可以使用RectTransformUtility类中的ScreenPointToLocalPointInRectangle方法来进行坐标系的转换。具体的代码实现如下所示: ``` Camera camera = GameObject.Find("Main Camera").GetComponent<Camera>(); RectTransform canvas = GameObject.Find("Canvas").GetComponent<RectTransform>(); // 获取世界坐标在Canvas中的相对坐标 Vector2 localPos = Vector3.zero; RectTransformUtility.ScreenPointToLocalPointInRectangle(canvas, camera.WorldToScreenPoint(transform.position), camera, out localPos); Debug.Log(localPos); // 遍历子物体,获取子物体在Canvas中的相对坐标 foreach (Transform trans in transform) { RectTransformUtility.ScreenPointToLocalPointInRectangle(canvas, camera.WorldToScreenPoint(trans.position), camera, out localPos); Debug.Log(localPos); } ``` 上述代码可以将世界坐标转换为指定Canvas的相对坐标。其中,`camera`表示主相机,`canvas`表示目标Canvas,`transform`表示需要转换的物体的Transform组件。通过调用`RectTransformUtility.ScreenPointToLocalPointInRectangle`方法,将世界坐标转换为Canvas中的相对坐标,并将结果存储在`localPos`变量中。 请注意,以上代码只是示例,您需要根据自己的具体场景进行相应的调整和修改。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Unity各种坐标转换](https://blog.csdn.net/qq_30058057/article/details/105413689)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Unity3d UI控件相对于Canvas坐标](https://blog.csdn.net/wangningzk123/article/details/107111468)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值