1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-21 23:53:57 +00:00
openmw/components/detournavigator/findrandompointaroundcircle.cpp

37 lines
1.2 KiB
C++
Raw Normal View History

#include "findrandompointaroundcircle.hpp"
#include "findsmoothpath.hpp"
2022-09-22 18:26:05 +00:00
#include "settings.hpp"
#include <DetourNavMesh.h>
#include <DetourNavMeshQuery.h>
namespace DetourNavigator
{
std::optional<osg::Vec3f> findRandomPointAroundCircle(const dtNavMesh& navMesh, const osg::Vec3f& halfExtents,
2022-09-22 18:26:05 +00:00
const osg::Vec3f& start, const float maxRadius, const Flags includeFlags, const DetourSettings& settings,
float (*prng)())
{
dtNavMeshQuery navMeshQuery;
if (!initNavMeshQuery(navMeshQuery, navMesh, settings.mMaxNavMeshQueryNodes))
return std::optional<osg::Vec3f>();
dtQueryFilter queryFilter;
queryFilter.setIncludeFlags(includeFlags);
dtPolyRef startRef = findNearestPoly(navMeshQuery, queryFilter, start, halfExtents * 4);
if (startRef == 0)
return std::optional<osg::Vec3f>();
dtPolyRef resultRef = 0;
osg::Vec3f resultPosition;
2022-09-22 18:26:05 +00:00
navMeshQuery.findRandomPointAroundCircle(
startRef, start.ptr(), maxRadius, &queryFilter, prng, &resultRef, resultPosition.ptr());
if (resultRef == 0)
return std::optional<osg::Vec3f>();
return std::optional<osg::Vec3f>(resultPosition);
}
}