#ifndef OPENMW_COMPONENTS_DETOURNAVIGATOR_MAKENAVMESH_H #define OPENMW_COMPONENTS_DETOURNAVIGATOR_MAKENAVMESH_H #include "recastmesh.hpp" #include "tileposition.hpp" #include #include class dtNavMesh; struct rcConfig; namespace DetourNavigator { struct Settings; struct PreparedNavMeshData; struct NavMeshData; struct OffMeshConnection; struct AgentBounds; struct RecastSettings; inline float getLength(const osg::Vec2i& value) { return std::sqrt(float(osg::square(value.x()) + osg::square(value.y()))); } inline float getDistance(const TilePosition& lhs, const TilePosition& rhs) { return getLength(lhs - rhs); } inline bool shouldAddTile(const TilePosition& changedTile, const TilePosition& playerTile, int maxTiles) { const auto expectedTilesCount = std::ceil(osg::PI * osg::square(getDistance(changedTile, playerTile))); return expectedTilesCount <= maxTiles; } inline bool isEmpty(const RecastMesh& recastMesh) { return recastMesh.getMesh().getIndices().empty() && recastMesh.getWater().empty() && recastMesh.getHeightfields().empty() && recastMesh.getFlatHeightfields().empty(); } std::unique_ptr prepareNavMeshTileData(const RecastMesh& recastMesh, const TilePosition& tilePosition, const AgentBounds& agentBounds, const RecastSettings& settings); NavMeshData makeNavMeshTileData(const PreparedNavMeshData& data, const std::vector& offMeshConnections, const AgentBounds& agentBounds, const TilePosition& tile, const RecastSettings& settings); void initEmptyNavMesh(const Settings& settings, dtNavMesh& navMesh); bool isSupportedAgentBounds(const RecastSettings& settings, const AgentBounds& agentBounds); } #endif