2023-03-14 08:02:43 +03:00
|
|
|
/*
|
|
|
|
recast4j copyright (c) 2021 Piotr Piastucki piotr@jtilia.org
|
|
|
|
|
|
|
|
This software is provided 'as-is', without any express or implied
|
|
|
|
warranty. In no event will the authors be held liable for any damages
|
|
|
|
arising from the use of this software.
|
|
|
|
Permission is granted to anyone to use this software for any purpose,
|
|
|
|
including commercial applications, and to alter it and redistribute it
|
|
|
|
freely, subject to the following restrictions:
|
|
|
|
1. The origin of this software must not be misrepresented; you must not
|
|
|
|
claim that you wrote the original software. If you use this software
|
|
|
|
in a product, an acknowledgment in the product documentation would be
|
|
|
|
appreciated but is not required.
|
|
|
|
2. Altered source versions must be plainly marked as such, and must not be
|
|
|
|
misrepresented as being the original software.
|
|
|
|
3. This notice may not be removed or altered from any source distribution.
|
|
|
|
*/
|
|
|
|
|
2023-03-25 09:43:20 +03:00
|
|
|
using static DotRecast.Core.RecastMath;
|
2023-03-14 08:02:43 +03:00
|
|
|
|
2023-03-16 19:09:10 +03:00
|
|
|
namespace DotRecast.Detour.Extras
|
|
|
|
{
|
2023-03-16 19:48:49 +03:00
|
|
|
public class BVTreeBuilder
|
|
|
|
{
|
|
|
|
public void build(MeshData data)
|
|
|
|
{
|
|
|
|
data.bvTree = new BVNode[data.header.polyCount * 2];
|
|
|
|
data.header.bvNodeCount = data.bvTree.Length == 0
|
|
|
|
? 0
|
2023-03-14 08:02:43 +03:00
|
|
|
: createBVTree(data, data.bvTree, data.header.bvQuantFactor);
|
2023-03-16 19:48:49 +03:00
|
|
|
}
|
2023-03-14 08:02:43 +03:00
|
|
|
|
2023-03-16 19:48:49 +03:00
|
|
|
private static int createBVTree(MeshData data, BVNode[] nodes, float quantFactor)
|
|
|
|
{
|
|
|
|
NavMeshBuilder.BVItem[] items = new NavMeshBuilder.BVItem[data.header.polyCount];
|
|
|
|
for (int i = 0; i < data.header.polyCount; i++)
|
|
|
|
{
|
|
|
|
NavMeshBuilder.BVItem it = new NavMeshBuilder.BVItem();
|
|
|
|
items[i] = it;
|
|
|
|
it.i = i;
|
2023-03-28 18:03:33 +03:00
|
|
|
Vector3f bmin = new Vector3f();
|
|
|
|
Vector3f bmax = new Vector3f();
|
2023-03-16 19:48:49 +03:00
|
|
|
vCopy(bmin, data.verts, data.polys[i].verts[0] * 3);
|
|
|
|
vCopy(bmax, data.verts, data.polys[i].verts[0] * 3);
|
|
|
|
for (int j = 1; j < data.polys[i].vertCount; j++)
|
|
|
|
{
|
|
|
|
vMin(bmin, data.verts, data.polys[i].verts[j] * 3);
|
|
|
|
vMax(bmax, data.verts, data.polys[i].verts[j] * 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
it.bmin[0] = clamp((int)((bmin[0] - data.header.bmin[0]) * quantFactor), 0, 0x7fffffff);
|
|
|
|
it.bmin[1] = clamp((int)((bmin[1] - data.header.bmin[1]) * quantFactor), 0, 0x7fffffff);
|
|
|
|
it.bmin[2] = clamp((int)((bmin[2] - data.header.bmin[2]) * quantFactor), 0, 0x7fffffff);
|
|
|
|
it.bmax[0] = clamp((int)((bmax[0] - data.header.bmin[0]) * quantFactor), 0, 0x7fffffff);
|
|
|
|
it.bmax[1] = clamp((int)((bmax[1] - data.header.bmin[1]) * quantFactor), 0, 0x7fffffff);
|
|
|
|
it.bmax[2] = clamp((int)((bmax[2] - data.header.bmin[2]) * quantFactor), 0, 0x7fffffff);
|
2023-03-14 08:02:43 +03:00
|
|
|
}
|
2023-03-16 19:48:49 +03:00
|
|
|
|
|
|
|
return NavMeshBuilder.subdivide(items, data.header.polyCount, 0, data.header.polyCount, 0, nodes);
|
2023-03-14 08:02:43 +03:00
|
|
|
}
|
|
|
|
}
|
2023-03-16 19:09:10 +03:00
|
|
|
}
|