Unity Translate方法使用指南

API 简介

Translate 方法是 Transform 类下的一个公共方法。一般可以用于物体的位移。
在这里插入图片描述

方法的第一个参数表示位移多少,一般用移动方向×速度 ×时间来表示。

方法的第二个参数表示相对于哪个坐标系进行移动。如果没有传第二个参数,默认是相对于自己的坐标系。

Translate 的不同用法组合

在介绍 Translate 方法的具体使用方式之前,我先画出世界坐标系和本地坐标系便于大家后续理解。

现在新建一个物体,假设它的世界坐标系是这样的:(刚刚创建的物体本地坐标系也和世界坐标系重合)
在这里插入图片描述

现在将物体绕 y 轴顺时针旋转一定角度。
在这里插入图片描述
现在黑色坐标系是世界坐标系,红色坐标系是物体旋转后的本地坐标系(因为是绕 y 轴转所以 y 轴不动,就不标红了)。


1)相对于自己坐标系下的z轴正方向移动(往面朝向移动)

transform.Translate(Vector3.forward*1*Time.deltaTime);

把物体当作人,那么就是朝人的前方移动。
这个比较好理解,就是在自己的坐标系下,往(0,0,1)的方向移动。在上图中就是沿着红色的 z 轴方向移动。

2)相对于世界坐标系下,自己的面朝向移动

transform.Translate(transform.forward*1*Time.deltaTime,Space.World);

效果和上面那种方法是相同的,都是沿着红色的 z 轴方向移动。

这里简单提一下 transform.forward,它代表了物体当前的面朝向(自身的z 轴指向),并且是相对于世界坐标系下的
在这里插入图片描述
也就是用自己坐标系下的(0,0,1)投影到世界坐标系下的各分量来表示 forward 得出的向量,以上面画的坐标系图为例,就是这样理解:
在这里插入图片描述
transform.forward 得出的向量就是(Zx,0,Zz),从黑色的世界坐标系来看就是沿着红色的 z 轴方向。

3)相对于世界坐标系下的z轴正方向移动

transform.Translate(Vector3.forward*1*Time.deltaTime,Space.World);  

此时物体只会朝黑色的 z 轴移动。

4)相对于自己坐标系下,自己的面朝向移动

(一般不会这样用)

transform.Translate(transform.forward*1*Time.deltaTime,Space.Self);

transform.forward 得到的向量是相对于世界坐标系的,可这时候我们要求相对于自己的坐标系,那么必须将原来 forward 得到的向量转化成自己坐标系的一个向量。这时候物体的移动方向也就不会是自己的面朝向了。
在这里插入图片描述
最后的移动方向是蓝色的 z’ 轴
以上面这张图为例,就是原先由黑色 z 轴转到红色 z 轴旋转了一定角度。然后再从红色 z 轴旋转相同的角度到蓝色 z’ 轴的方向(有点像将原来的世界坐标系旋转到红色的坐标系,那么原本相对于黑色坐标系的红色 z 轴就相应变成了相对于原本红色坐标系的蓝色 z’ 轴)。

总结
如果想实现物体沿自身方向移动,比如游戏中常见的人物移动,参考前两种方法就好了。尤其注意不要掉入最后一种方式的陷阱,因为有可能会写成 :

transform.Translate(transform.forward*1*Time.deltaTime);

那么它是无法实现我们正常想要看到的人物移动效果的。

  • 18
    点赞
  • 64
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
transform.Translate()函数是Unity引擎中用于对物体进行平移操作的函数。该函数接受两个参数,第一个参数是物体的移动速度,也就是一个矢量,包含了大小和方向。第二个参数是相对坐标系,用于指定物体相对于哪个坐标系进行移动。如果不填写第二个参数,默认为物体的自身坐标系。这里的transform.forward表示物体的前方向。同样地,我们也可以使用transform.Translate(Vector3.forward * curSpeed, Space.World)来实现相同的效果。 综上所述,transform.Translate()函数可以用于实现物体的平移操作,通过调整参数可以实现在不同方向和坐标系下的移动。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [unity物体移动三种方式之——Transform.Translate](https://blog.csdn.net/liyuerge/article/details/79134337)[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^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [物体的移动Transform.Translate函数](https://blog.csdn.net/qq2465922953/article/details/128223907)[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^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YY-nb

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值