UnityAPI.Vector3三维向量

表示3D的向量和点。

这个结构用于在Unity传递3D位置和方向。它也包含做些普通向量运算的函数。

除了下面列出的函数,其他类用于处理向量和点。例如Quaternion和Matrix4x4类用于旋转或变换向量和点。

UnityAPI.Vector3三维向量_第1张图片
UnityAPI.Vector3三维向量_第2张图片
UnityAPI.Vector3三维向量_第3张图片

1、Vector3.this[int] 操作索引

使用[0], [1], [2]分别访问组件x, y, z组件。简单来说就是用索引号代替x, y, z组件。

using UnityEngine;

using System.Collections;

public class ExampleClass : MonoBehaviour {

    public Vector3 p;

    void Example() {

        p[1] = 5;

    }

}


API详解


A、Vector3类实例属性

1、normalized:单位化向量

public Vector3 normalized{ get; }

此属性用来获取Vector3实例的单位向量,即返回向量的方向与原方向相同,而模长变为1。

此属性和实例方法Normalized( )的区别:

设A、C均为Vector3实例,则:

执行代码C=A.normalized后只是将向量A的单位向量赋给向量C,而向量A自身未变

执行代码A=Normalize()便会将向量A进行单位化处理,使得原向量A变成了单位向量

执行代码C=Vector3.Normalize(A)的结果与执行代码C=A.normalized的相同,即只是将A的单位向量赋给了向量C,而向量A未被改变,因此编程中常用代码C=A.normalized代替。


2、sqrMagnitude:模长平方

public float sqrMagnitude{ get; }

此属性用于返回Vector3实例模长的平方值,由于计算开方值比较消耗资源,在非必要情况下,可以考虑用

sqrMagnitude代替属性magnitude,例如比较两个向量长度的大小


B、Vector3类实例方法

1、Scale:向量放缩

public void Scale(Vector3 scale);

此方法可以对Vector3实例按参照向量scale进行放缩,注意与静态方法Scale(a:Vector3,b:Vector3)的区别:

实例方法直接更改实例的值,静态方法将值赋给新的实例


C、Vector3类静态方法

1、Angle:求两个向量夹角

public static float Angle(Vector3 from, Vector3 to );

返回向量from和to的夹角,单位为角度,返回值的范围为[0,180],且当from和to至少一个为Vector.zero时,返回值为90


2、ClampMagnitude:向量长度

public static Vector3 ClampMagnitude(Vector3 vector,float maxLength);

此方法用于返回向量vector3的一个同方向向量,其模长受maxLength的限制

返回向量的方向和vector方向相同

当maxLength大于vector的模长时,返回向量与vector相同

当maxLength小于vector的模长时,返回向量的模长等于maxLength,但方向与vector相同


3、Cross方法:向量叉乘

public static Vector3 Cross(Vector3 lhs,Vector3 rhs);

此方法用于求两个向量的叉乘,满足:

c⊥a,c⊥b;

|c|=|a|*|b|sin(e);

a,b,c满足右手法则,即四指指向b的方向,然后向a的方向旋转,大拇指指向的方向是c的方向


4、Dot:向量点乘

public static float Dot(Vector3 lhs, Vector3 rhs);

此方法用于返回参数lhs和rhs的点乘

c=Vector3.Dot( a,b );

c=|a|*|b|cos(e)

在实际开发中,通常利用点乘来确定两个物体的相对位置关系,例如敌人相对主角的位置关系


5、Lerp:向量插值

public static Vector3 Lerp(Vector3 from, Vector3 to, float t);

此方法用于返回一个参数from到to的线性插值向量

C=Vector3.Lerp(A,B,t)

当t<=0时,向量C=A;

当t>=1时,向量C=B;

当0


6、MoveTowards:向量插值

public static Vector3 MoveTowards(Vector3 current, Vector3 target, float maxDistanceDelta);

此方法用于返回一个从参数current到参数target的插值向量。

C=Vector3.MoveTowards(A,B,sp);

向量C为:C=A+K*(B-A)

其中K=sp>(dx^2+dy^2+dz^2)^(1/2)?1:sp/(dx^2+dy^2+dz^2)^(1/2)


7、OrthoNormalize:两个坐标轴的正交化

public static void OrthoNormalize(ref Vector3 normal, ref Vector3 tangent);

此方法用于对向量normal进行单位化处理,并对向量tangent进行正交化处理

Vector3.OrthoNormalize(ref v1, ref v2);

v1、v2变换为v3、v4

v3=v1.normalized

v4与v3垂直,且v4模长为1


8、OrthoNormalize:3个坐标轴的正交化

public static void OrthoNormalize(ref Vector3 normal, ref Vector3 tangent,ref Vecotor3 binormal );

此方法用于对向量normal进行单位化处理,并对向量tangent和binormal进行正交化处理

向量binormal垂直于向量normal和tangent组成的平面,且向量binormal变换前后的夹角小于90度,即执行OrthoNormalize之后,bi'normal的方向可能垂直于由normal和tangent组成的平面的正面也可能是负面,到底垂直于哪个面由初始binormal的方向决定


9、Project:投影向量

public static Vector3 Project(Vector3 vector,Vector3 onNormal);

此方法用于返回向量vector在向量onNormal上的投影向量

projects=Vector3.Project(from_T.position,to_T.position);

projects为from_T在to_T方向上的投影向量,另外,向量to_T无需为单位向量


10、Reflect:反射向量

public static Vector3 Reflect(Vector3 inDirection,Vector3 inNormal);

其中,参数inDirection为入射向量,参数inNormal为镜面向量

此方法用于返回向量inDi'rection的反射向量

参数inNormal向量必须为单位向量,否则入射角和反射角不相等

当inNormal取反时,反射向量不受影响

入射向量、反射向量和镜面向量共面


11、RotateTowards:球形插值

public static Vector3 RotateTowards(Vector3 ccurrent, Vector3 target, float maxRadiansDelta,

float maxMagnitudeDelta);

其中参数current到target的球形旋转插值向量,此方法可控制插值向量的角度和模长


12、Scale:向量放缩

public static Vector3 Scale(Vector3 a, Vector3 b);

此方法用于返回向量a和b的乘积,注意和实例方法a.Scale(b)的区别


13、Slerp:球形插值

public static Vector3 Slerp(Vector3 from,Vector3 to,float t);

此方法用于返回参数from点到参数to点的球形插值向量,参数t范围为[0,1]

C=Vector3.Slerp(from,to,t);

K=e*(1-t)

|C|=(ax^2+ay^2+az^2)^(1/2)+[(bx^2+by^2+bz^2)^(1/2)-(ax^2+ay^2-az^2)^(1/2)]*t


14、SmoothDamp:阻尼移动

public static Vector3 SmoothDamp(Vector3 current,Vector3 target,ref Vector3 currentVelocity,

float smoothTime);

public static Vector3 SmoothDamp(Vector3 current,Vector3 target,ref Vector3 currentVelocity,

float smoothTime,float maxSpeed);

public static Vector3 SmoothDamp(Vector3 current,Vector3 target,ref Vector3 currentVelocity,

float smoothTime,float maxSpeed,float deltaTime);

current为起始坐标,target为终点坐标,currentVelocity为当前帧移动向量,参数smoothTime为接近目标的阻尼强度,

参数maxSpeed为最大移动速度,默认值为无穷大,参数deltaTime为控制当前帧实际移动距离,即为maxSpeed*deltaTime,

默认值为Time.deltaTime

此方法用于模拟GameObject对象从current点到target点之间的阻尼运动


D、Vector3类运算符

1、operator==

用于判断向量是否足够接近或相等


经验总结:

控制游戏对象向目标点移动有三种方法:

(1)、用Lerp方法(插值函数):

this.gameObject.transform.position=Vector3.Lerp(this.gameObject.transform.position,target.transform.position,speed);

(2)、用MoveTowards方法

this.gameObject.transform.position=Vector3.MoveTowards(this.gameObject.transform.position, target.transform.position,speed);

(3)、用Distance和Translate方法

if(Vector3.Distance(this.gameObject.transform.position,target.transform.position)>0.1)

   {

      this.gameObject.transform.Translate(target.transform.up);

}

三者之间的不同点:

用Lerp方法控制游戏对象向目标点移动,其是按比例进行移动的,只能无限接近,不能到达目标位置点。

用MoveTowards方法控制游戏对象向目标点移动,每次移动一个设定的步长,其可以到达目标位置点。


用Distance和Translate方法控制游戏对象向目标点移动,有很大的局限性,其必须先要知道要移动的方向才可以,况且只能是正方向,并且其也只能接近,不能到达目标点位置。

你可能感兴趣的:(UnityAPI.Vector3三维向量)