mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-24 18:23:54 +00:00
e00eb50587
This is not used anyway. There are features like smooth movement which remove all redundant points. Use single findStraightPath call instead of multiple.
32 lines
1 KiB
C++
32 lines
1 KiB
C++
#include "findrandompointaroundcircle.hpp"
|
|
|
|
#include <DetourNavMesh.h>
|
|
#include <DetourNavMeshQuery.h>
|
|
|
|
namespace DetourNavigator
|
|
{
|
|
std::optional<osg::Vec3f> findRandomPointAroundCircle(const dtNavMeshQuery& navMeshQuery,
|
|
const osg::Vec3f& halfExtents, const osg::Vec3f& start, const float maxRadius, const Flags includeFlags,
|
|
float (*prng)())
|
|
{
|
|
dtQueryFilter queryFilter;
|
|
queryFilter.setIncludeFlags(includeFlags);
|
|
|
|
dtPolyRef startRef = 0;
|
|
const dtStatus status
|
|
= navMeshQuery.findNearestPoly(start.ptr(), halfExtents.ptr(), &queryFilter, &startRef, nullptr);
|
|
if (dtStatusFailed(status))
|
|
return std::nullopt;
|
|
|
|
dtPolyRef resultRef = 0;
|
|
osg::Vec3f resultPosition;
|
|
|
|
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);
|
|
}
|
|
}
|