mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 06:26:36 +00:00
This prevents actors going back when a new shortest path includes a point behind them where they were right before. Such situation can happen when path includes off mesh connection. Resulting cost of such path can be lower than the real one because off mesh connections are straight lines and walking surface usually is not a plane but a surface. Skip to path point where distance from current position to the line between previous and this point is less than point tolerance. Which means actor is standing very close to the edge between those points. Additionally check by navmesh raycasting to make sure there is actually a valid path.
16 lines
358 B
C++
16 lines
358 B
C++
#ifndef OPENMW_COMPONENTS_MISC_MATH_H
|
|
#define OPENMW_COMPONENTS_MISC_MATH_H
|
|
|
|
#include <osg/Vec3f>
|
|
|
|
namespace Misc
|
|
{
|
|
inline osg::Vec3f getVectorToLine(const osg::Vec3f& position, const osg::Vec3f& a, const osg::Vec3f& b)
|
|
{
|
|
osg::Vec3f direction = b - a;
|
|
direction.normalize();
|
|
return (position - a) ^ direction;
|
|
}
|
|
}
|
|
|
|
#endif
|