forked from bit/DotRecastNetSim
remove IConvexVolumeProvider
This commit is contained in:
parent
bac7a76258
commit
90f48d1021
|
@ -1,29 +0,0 @@
|
||||||
/*
|
|
||||||
recast4j copyright (c) 2021 Piotr Piastucki piotr@jtilia.org
|
|
||||||
DotRecast Copyright (c) 2023 Choi Ikpil ikpil@naver.com
|
|
||||||
|
|
||||||
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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
|
|
||||||
namespace DotRecast.Recast.Geom
|
|
||||||
{
|
|
||||||
public interface IConvexVolumeProvider
|
|
||||||
{
|
|
||||||
void AddConvexVolume(RcConvexVolume convexVolume);
|
|
||||||
IList<RcConvexVolume> ConvexVolumes();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -24,7 +24,7 @@ using DotRecast.Core;
|
||||||
|
|
||||||
namespace DotRecast.Recast.Geom
|
namespace DotRecast.Recast.Geom
|
||||||
{
|
{
|
||||||
public interface IInputGeomProvider : IConvexVolumeProvider
|
public interface IInputGeomProvider
|
||||||
{
|
{
|
||||||
RcVec3f GetMeshBoundsMin();
|
RcVec3f GetMeshBoundsMin();
|
||||||
|
|
||||||
|
@ -32,6 +32,10 @@ namespace DotRecast.Recast.Geom
|
||||||
|
|
||||||
IEnumerable<RcTriMesh> Meshes();
|
IEnumerable<RcTriMesh> Meshes();
|
||||||
|
|
||||||
|
// convex volume
|
||||||
|
void AddConvexVolume(RcConvexVolume convexVolume);
|
||||||
|
IList<RcConvexVolume> ConvexVolumes();
|
||||||
|
|
||||||
// off mesh connections
|
// off mesh connections
|
||||||
public List<DtOffMeshConnectionParam> GetOffMeshConnections();
|
public List<DtOffMeshConnectionParam> GetOffMeshConnections();
|
||||||
public void AddOffMeshConnection(RcVec3f start, RcVec3f end, float radius, bool bidir, int area, int flags);
|
public void AddOffMeshConnection(RcVec3f start, RcVec3f end, float radius, bool bidir, int area, int flags);
|
||||||
|
|
|
@ -166,7 +166,7 @@ namespace DotRecast.Recast
|
||||||
return Build(builderCfg.tileX, builderCfg.tileZ, geom, cfg, solid, ctx);
|
return Build(builderCfg.tileX, builderCfg.tileZ, geom, cfg, solid, ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
public RecastBuilderResult Build(int tileX, int tileZ, IConvexVolumeProvider geom, RcConfig cfg, RcHeightfield solid, RcTelemetry ctx)
|
public RecastBuilderResult Build(int tileX, int tileZ, IInputGeomProvider geom, RcConfig cfg, RcHeightfield solid, RcTelemetry ctx)
|
||||||
{
|
{
|
||||||
FilterHeightfield(solid, cfg, ctx);
|
FilterHeightfield(solid, cfg, ctx);
|
||||||
RcCompactHeightfield chf = BuildCompactHeightfield(geom, cfg, ctx, solid);
|
RcCompactHeightfield chf = BuildCompactHeightfield(geom, cfg, ctx, solid);
|
||||||
|
@ -280,7 +280,7 @@ namespace DotRecast.Recast
|
||||||
/*
|
/*
|
||||||
* Step 3. Partition walkable surface to simple regions.
|
* Step 3. Partition walkable surface to simple regions.
|
||||||
*/
|
*/
|
||||||
private RcCompactHeightfield BuildCompactHeightfield(IConvexVolumeProvider volumeProvider, RcConfig cfg, RcTelemetry ctx,
|
private RcCompactHeightfield BuildCompactHeightfield(IInputGeomProvider geom, RcConfig cfg, RcTelemetry ctx,
|
||||||
RcHeightfield solid)
|
RcHeightfield solid)
|
||||||
{
|
{
|
||||||
// Compact the heightfield so that it is faster to handle from now on.
|
// Compact the heightfield so that it is faster to handle from now on.
|
||||||
|
@ -291,9 +291,9 @@ namespace DotRecast.Recast
|
||||||
// Erode the walkable area by agent radius.
|
// Erode the walkable area by agent radius.
|
||||||
RecastArea.ErodeWalkableArea(ctx, cfg.WalkableRadius, chf);
|
RecastArea.ErodeWalkableArea(ctx, cfg.WalkableRadius, chf);
|
||||||
// (Optional) Mark areas.
|
// (Optional) Mark areas.
|
||||||
if (volumeProvider != null)
|
if (geom != null)
|
||||||
{
|
{
|
||||||
foreach (RcConvexVolume vol in volumeProvider.ConvexVolumes())
|
foreach (RcConvexVolume vol in geom.ConvexVolumes())
|
||||||
{
|
{
|
||||||
RecastArea.MarkConvexPolyArea(ctx, vol.verts, vol.hmin, vol.hmax, vol.areaMod, chf);
|
RecastArea.MarkConvexPolyArea(ctx, vol.verts, vol.hmin, vol.hmax, vol.areaMod, chf);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue