Unity3D 一些基础的3D图形学算法


原创文章如需转载请注明:转载自 脱莫柔Unity3D学习之旅 QQ群:【Unity3D(AR/VR) 334163814】【Unity3D(游戏) 119706192】 本文链接地址:Unity3D 一些基础的3D图形学算法

最近做一款一款3D“跑酷”游戏终于要上线了,很开森,忙里偷闲分享点常用的一些基础算法。

另外感兴趣的朋友可以去上网下载下来玩玩 ,游戏叫《让小编飞》,嘿嘿、

ps:最近使用中文编程~强迫症们,来咬我啊!

1..A点正前方,10米位置的坐标点


代码:
public Transform A;
public Transform Z;


void Start () 
{
    正前方();
    Debug.Log("Distance:" + Vector3.Distance(A.transform.position, Z.transform.position));
}

void 正前方()
{
    Z.transform.position = A.transform.position + Vector3.forward * 10f;
}

运行结果:


2.A点前方Y轴45°,10米位置的坐标点

直接上代码:
void 斜前方()
{
    Quaternion q = Quaternion.Euler(0, 45, 0);
    Z.transform.position = A.transform.position + q * Vector3.forward * 10f;
}

运行结果:


3.A点到B点方向,10米位置的坐标点


柱子是B点。
这个例子用3D视角来做。
代码:
void 到B方向正前方()
{
    Vector3 方向 = (B.transform.position - A.transform.position).normalized;
    Quaternion q = Quaternion.LookRotation(方向);
    Z.transform.position = A.transform.position + q * Vector3.forward * 10f;

    Debug.Log("Distance A-B:" + Vector3.Distance(A.transform.position, B.transform.position));
}

运行结果:


4.A点到B点方向Y轴偏移45°,10米位置的坐标点

这个例子将B点与A点放在了同一高度,继续使用2D视角。
代码:
void 到B方向斜前方()
{
    Vector3 方向 = (B.transform.position - A.transform.position).normalized;
    Quaternion q = Quaternion.LookRotation(方向) * Quaternion.Euler(0,45,0);
    Z.transform.position = A.transform.position + q * Vector3.forward * 10f;

    Debug.Log("Distance A-B:" + Vector3.Distance(A.transform.position, B.transform.position));
}

运行结果:

到此展示完毕~
谢谢参观~!