1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-24 23:53:50 +00:00
openmw-tes3mp/apps/openmw/mwmechanics/obstacle.hpp

64 lines
1.6 KiB
C++
Raw Normal View History

#ifndef OPENMW_MECHANICS_OBSTACLE_H
2014-04-18 06:45:31 +00:00
#define OPENMW_MECHANICS_OBSTACLE_H
#include <osg/Vec3f>
namespace MWWorld
{
class Ptr;
}
namespace MWMechanics
{
struct Movement;
static constexpr int NUM_EVADE_DIRECTIONS = 4;
/// tests actor's proximity to a closed door by default
bool proximityToDoor(const MWWorld::Ptr& actor, float minDist);
2016-12-14 15:39:33 +00:00
/// Returns door pointer within range. No guarantee is given as to which one
2018-10-09 06:21:12 +00:00
/** \return Pointer to the door, or empty pointer if none exists **/
const MWWorld::Ptr getNearbyDoor(const MWWorld::Ptr& actor, float minDist);
class ObstacleCheck
{
public:
ObstacleCheck();
// Clear the timers and set the state machine to default
void clear();
bool isEvading() const;
2018-08-18 15:26:00 +00:00
// Updates internal state, call each frame for moving actor
void update(const MWWorld::Ptr& actor, const osg::Vec3f& destination, float duration);
// change direction to try to fix "stuck" actor
2018-08-18 20:17:52 +00:00
void takeEvasiveAction(MWMechanics::Movement& actorMovement) const;
private:
osg::Vec3f mPrev;
// directions to try moving in when get stuck
static const float evadeDirections[NUM_EVADE_DIRECTIONS][2];
enum class WalkState
{
Initial,
Norm,
CheckStuck,
Evade
};
WalkState mWalkState;
float mStateDuration;
int mEvadeDirectionIndex;
float mInitialDistance = 0;
void chooseEvasionDirection();
};
}
#endif