mirror of
				https://github.com/TES3MP/openmw-tes3mp.git
				synced 2025-10-26 08:56:40 +00:00 
			
		
		
		
	In AiWander, if wander distance is set too small to get two points, take the closest two points.
		
			
				
	
	
		
			137 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			137 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef GAME_MWMECHANICS_AIWANDER_H
 | |
| #define GAME_MWMECHANICS_AIWANDER_H
 | |
| 
 | |
| #include "aipackage.hpp"
 | |
| 
 | |
| #include <vector>
 | |
| 
 | |
| #include <OgreVector3.h>
 | |
| 
 | |
| #include "pathfinding.hpp"
 | |
| #include "obstacle.hpp"
 | |
| 
 | |
| #include "../mwworld/timestamp.hpp"
 | |
| 
 | |
| 
 | |
| #include "aistate.hpp"
 | |
| 
 | |
| namespace ESM
 | |
| {
 | |
|     struct Cell;
 | |
|     namespace AiSequence
 | |
|     {
 | |
|         struct AiWander;
 | |
|     }
 | |
| }
 | |
| 
 | |
| namespace MWMechanics
 | |
| {    
 | |
|     
 | |
|     
 | |
|     struct AiWanderStorage;
 | |
| 
 | |
|     /// \brief Causes the Actor to wander within a specified range
 | |
|     class AiWander : public AiPackage
 | |
|     {
 | |
|         public:
 | |
|             /// Constructor
 | |
|             /** \param distance Max distance the ACtor will wander
 | |
|                 \param duration Time, in hours, that this package will be preformed
 | |
|                 \param timeOfDay Start time of the package, if it has a duration. Currently unimplemented
 | |
|                 \param idle Chances of each idle to play (9 in total)
 | |
|                 \param repeat Repeat wander or not **/
 | |
|             AiWander(int distance, int duration, int timeOfDay, const std::vector<unsigned char>& idle, bool repeat);
 | |
| 
 | |
|             AiWander (const ESM::AiSequence::AiWander* wander);
 | |
| 
 | |
|             
 | |
| 
 | |
|             virtual AiPackage *clone() const;
 | |
| 
 | |
|             virtual bool execute (const MWWorld::Ptr& actor, AiState& state, float duration);
 | |
| 
 | |
|             virtual int getTypeId() const;
 | |
| 
 | |
|             /// Set the position to return to for a stationary (non-wandering) actor
 | |
|             /** In case another AI package moved the actor elsewhere **/
 | |
|             void setReturnPosition (const Ogre::Vector3& position);
 | |
| 
 | |
|             virtual void writeState(ESM::AiSequence::AiSequence &sequence) const;
 | |
| 
 | |
|             virtual void fastForward(const MWWorld::Ptr& actor, AiState& state);
 | |
|             
 | |
|             enum GreetingState {
 | |
|                 Greet_None,
 | |
|                 Greet_InProgress,
 | |
|                 Greet_Done
 | |
|             };
 | |
|         private:
 | |
|             // NOTE: mDistance and mDuration must be set already
 | |
|             void init();
 | |
|             
 | |
|             void stopWalking(const MWWorld::Ptr& actor, AiWanderStorage& storage);
 | |
|             void playIdle(const MWWorld::Ptr& actor, unsigned short idleSelect);
 | |
|             bool checkIdle(const MWWorld::Ptr& actor, unsigned short idleSelect);
 | |
|             void getRandomIdle(unsigned short& playedIdle);
 | |
| 
 | |
|             int mDistance; // how far the actor can wander from the spawn point
 | |
|             int mDuration;
 | |
|             int mTimeOfDay;
 | |
|             std::vector<unsigned char> mIdle;
 | |
|             bool mRepeat;
 | |
|             
 | |
| 
 | |
|             bool mHasReturnPosition; // NOTE: Could be removed if mReturnPosition was initialized to actor position,
 | |
|                                     // if we had the actor in the AiWander constructor...
 | |
|             Ogre::Vector3 mReturnPosition;
 | |
| 
 | |
|             Ogre::Vector3 mInitialActorPosition;
 | |
|             bool mStoredInitialActorPosition;
 | |
| 
 | |
|            
 | |
| 
 | |
|             // if false triggers calculating allowed nodes based on mDistance
 | |
|             bool mStoredAvailableNodes;
 | |
| 
 | |
| 
 | |
|             
 | |
| 
 | |
|             MWWorld::TimeStamp mStartTime;
 | |
| 
 | |
|             // allowed pathgrid nodes based on mDistance from the spawn point
 | |
|             std::vector<ESM::Pathgrid::Point> mAllowedNodes;
 | |
| 
 | |
|             void getAllowedNodes(const MWWorld::Ptr& actor, const ESM::Cell* cell);
 | |
| 
 | |
|             ESM::Pathgrid::Point mCurrentNode;
 | |
|             bool mTrimCurrentNode;
 | |
|             void trimAllowedNodes(std::vector<ESM::Pathgrid::Point>& nodes,
 | |
|                                   const PathFinder& pathfinder);
 | |
| 
 | |
| 
 | |
| //             ObstacleCheck mObstacleCheck;
 | |
|             float mDoorCheckDuration;
 | |
|             int mStuckCount;
 | |
| 
 | |
|             // constants for converting idleSelect values into groupNames
 | |
|             enum GroupIndex
 | |
|             {
 | |
|                 GroupIndex_MinIdle = 2,
 | |
|                 GroupIndex_MaxIdle = 9
 | |
|             };
 | |
| 
 | |
|             /// lookup table for converting idleSelect value to groupName
 | |
|             static const std::string sIdleSelectToGroupName[GroupIndex_MaxIdle - GroupIndex_MinIdle + 1];
 | |
| 
 | |
|             /// record distances of pathgrid point nodes to actor
 | |
|             /// first value is distance between actor and node, second value is PathGrid node
 | |
|             typedef std::pair<float, const ESM::Pathgrid::Point*> PathDistance;
 | |
| 
 | |
|             /// used to sort array of PathDistance objects into ascending order
 | |
|             static bool sortByDistance(const PathDistance& left, const PathDistance& right);
 | |
|     };
 | |
|     
 | |
|     
 | |
| }
 | |
| 
 | |
| #endif
 |