Unity NavMesh可用于实现A *算法吗?

时间:2017-04-13 16:27:01

标签: c# unity3d a-star navmesh

我期待着为我正在进行的游戏使用A *寻路。 (我实际上是在为自己制作游戏来了解这一点)。我想知道Unity NavMesh如何与自定义A *算法一起使用,而不是使用NavMeshAgent。

2 个答案:

答案 0 :(得分:2)

没有

或者至少,不容易(为什么你想要?)。

Unity的内置NavMesh旨在由Unity的内置NavMeshAgent使用内置路径查找器。我不知道它使用什么算法,但A *实现通常在网络上运行。即,由边连接的节点。它不考虑内部体积(网格'面')。

由于Unity的内置版本用于此类,因此很难直接访问任何信息以用于您自己的寻路算法。

如果你想编写自己的探路者,那么我也建议你编写自己的网格。

答案 1 :(得分:1)

您可以执行以下操作:

var navMesh = NavMesh.CalculateTriangulation() // get baked Navigation Mesh Data;
Vector3[] vertices = navMesh.vertices;
int[] polygons = navMesh.indices;

顶点(显然)是导航网格的顶点,由它们在单位空间中的位置指示。网格由多边形定义。多边形数组显示哪个顶点属于哪个多边形。

polygons:
0 0
1 0
2 1
3 1
4 0
5 1

此数组将指示索引为0,1,4的顶点属于多边形编号0,索引为2,3,5的顶点属于多边形编号1。

您的导航网格为多边形。您可以定义搜索图并运行您选择的搜索算法。