mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 02:56:43 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "findrandompointaroundcircle.hpp"
 | |
| #include "settings.hpp"
 | |
| #include "findsmoothpath.hpp"
 | |
| 
 | |
| #include <components/misc/rng.hpp>
 | |
| 
 | |
| #include <DetourCommon.h>
 | |
| #include <DetourNavMesh.h>
 | |
| #include <DetourNavMeshQuery.h>
 | |
| 
 | |
| namespace DetourNavigator
 | |
| {
 | |
|     std::optional<osg::Vec3f> findRandomPointAroundCircle(const dtNavMesh& navMesh, const osg::Vec3f& halfExtents,
 | |
|         const osg::Vec3f& start, const float maxRadius, const Flags includeFlags, const Settings& settings)
 | |
|     {
 | |
|         dtNavMeshQuery navMeshQuery;
 | |
|         if (!initNavMeshQuery(navMeshQuery, navMesh, settings.mMaxNavMeshQueryNodes))
 | |
|             return std::optional<osg::Vec3f>();
 | |
| 
 | |
|         dtQueryFilter queryFilter;
 | |
|         queryFilter.setIncludeFlags(includeFlags);
 | |
| 
 | |
|         dtPolyRef startRef = 0;
 | |
|         osg::Vec3f startPolygonPosition;
 | |
|         for (int i = 0; i < 3; ++i)
 | |
|         {
 | |
|             const auto status = navMeshQuery.findNearestPoly(start.ptr(), (halfExtents * (1 << i)).ptr(), &queryFilter,
 | |
|                 &startRef, startPolygonPosition.ptr());
 | |
|             if (!dtStatusFailed(status) && startRef != 0)
 | |
|                 break;
 | |
|         }
 | |
| 
 | |
|         if (startRef == 0)
 | |
|             return std::optional<osg::Vec3f>();
 | |
| 
 | |
|         dtPolyRef resultRef = 0;
 | |
|         osg::Vec3f resultPosition;
 | |
|         navMeshQuery.findRandomPointAroundCircle(startRef, start.ptr(), maxRadius, &queryFilter,
 | |
|             []() { return Misc::Rng::rollProbability(); }, &resultRef, resultPosition.ptr());
 | |
| 
 | |
|         if (resultRef == 0)
 | |
|             return std::optional<osg::Vec3f>();
 | |
| 
 | |
|         return std::optional<osg::Vec3f>(resultPosition);
 | |
|     }
 | |
| }
 |