1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-21 23:53:57 +00:00
openmw/components/detournavigator/navigator.hpp

211 lines
8.7 KiB
C++
Raw Normal View History

#ifndef OPENMW_COMPONENTS_DETOURNAVIGATOR_NAVIGATOR_H
2018-03-13 22:49:08 +00:00
#define OPENMW_COMPONENTS_DETOURNAVIGATOR_NAVIGATOR_H
2019-02-16 12:27:02 +00:00
#include "objectid.hpp"
#include "navmeshcacheitem.hpp"
2019-11-27 22:45:01 +00:00
#include "recastmeshtiles.hpp"
#include "waitconditiontype.hpp"
#include "heightfieldshape.hpp"
2021-11-04 00:57:27 +00:00
#include "objecttransform.hpp"
#include <components/resource/bulletshape.hpp>
#include <string_view>
namespace ESM
{
struct Cell;
struct Pathgrid;
}
namespace Loading
{
class Listener;
}
2018-03-13 22:49:08 +00:00
namespace DetourNavigator
{
struct Settings;
2018-07-12 08:44:11 +00:00
struct ObjectShapes
{
osg::ref_ptr<const Resource::BulletShapeInstance> mShapeInstance;
2021-11-04 00:57:27 +00:00
ObjectTransform mTransform;
2018-07-12 08:44:11 +00:00
2021-11-04 00:57:27 +00:00
ObjectShapes(const osg::ref_ptr<const Resource::BulletShapeInstance>& shapeInstance, const ObjectTransform& transform)
: mShapeInstance(shapeInstance)
2021-11-04 00:57:27 +00:00
, mTransform(transform)
{
assert(mShapeInstance != nullptr);
}
2018-07-12 08:44:11 +00:00
};
struct DoorShapes : ObjectShapes
{
osg::Vec3f mConnectionStart;
osg::Vec3f mConnectionEnd;
DoorShapes(const osg::ref_ptr<const Resource::BulletShapeInstance>& shapeInstance,
2021-11-04 00:57:27 +00:00
const ObjectTransform& transform, const osg::Vec3f& connectionStart, const osg::Vec3f& connectionEnd)
: ObjectShapes(shapeInstance, transform)
, mConnectionStart(connectionStart)
, mConnectionEnd(connectionEnd)
{}
};
2018-09-29 22:20:42 +00:00
/**
2019-02-16 12:27:02 +00:00
* @brief Top level interface of detournavigator component. Navigator allows to build a scene with navmesh and find
2018-09-29 22:20:42 +00:00
* a path for an agent there. Scene contains agents, geometry objects and water. Agent are distinguished only by
* half extents. Each object has unique identifier and could be added, updated or removed. Water could be added once
* for each world cell at given level of height. Navmesh builds asynchronously in separate threads. To start build
* navmesh call update method.
*/
2019-02-16 12:27:02 +00:00
struct Navigator
2018-03-13 22:49:08 +00:00
{
2019-02-16 12:27:02 +00:00
virtual ~Navigator() = default;
2018-03-13 22:49:08 +00:00
2018-09-29 22:20:42 +00:00
/**
* @brief addAgent should be called for each agent even if all of them has same half extents.
* @param agentHalfExtents allows to setup bounding cylinder for each agent, for each different half extents
* there is different navmesh.
*/
2019-02-16 12:27:02 +00:00
virtual void addAgent(const osg::Vec3f& agentHalfExtents) = 0;
2018-03-13 22:49:08 +00:00
2018-09-29 22:20:42 +00:00
/**
* @brief removeAgent should be called for each agent even if all of them has same half extents
* @param agentHalfExtents allows determine which agent to remove
*/
2019-02-16 12:27:02 +00:00
virtual void removeAgent(const osg::Vec3f& agentHalfExtents) = 0;
2018-03-13 22:49:08 +00:00
/**
* @brief setWorldspace should be called before adding object from new worldspace
* @param worldspace
*/
virtual void setWorldspace(std::string_view worldspace) = 0;
/**
* @brief updateBounds should be called before adding object from loading cell
* @param playerPosition corresponds to the bounds center
*/
virtual void updateBounds(const osg::Vec3f& playerPosition) = 0;
2018-09-29 22:20:42 +00:00
/**
* @brief addObject is used to add complex object with allowed to walk and avoided to walk shapes
* @param id is used to distinguish different objects
* @param shape members must live until object is updated by another shape removed from Navigator
* @param transform allows to setup objects geometry according to its world state
* @return true if object is added, false if there is already object with given id
*/
2019-02-16 12:27:02 +00:00
virtual bool addObject(const ObjectId id, const ObjectShapes& shapes, const btTransform& transform) = 0;
2018-07-12 08:44:11 +00:00
2018-09-29 22:20:42 +00:00
/**
* @brief addObject is used to add doors.
* @param id is used to distinguish different objects.
* @param shape members must live until object is updated by another shape or removed from Navigator.
* @param transform allows to setup objects geometry according to its world state.
* @return true if object is added, false if there is already object with given id.
*/
2019-02-16 12:27:02 +00:00
virtual bool addObject(const ObjectId id, const DoorShapes& shapes, const btTransform& transform) = 0;
2018-09-29 22:20:42 +00:00
/**
* @brief updateObject replace object geometry by given data.
* @param id is used to find object.
* @param shape members must live until object is updated by another shape removed from Navigator.
* @param transform allows to setup objects geometry according to its world state.
* @return true if object is updated, false if there is no object with given id.
*/
2019-02-16 12:27:02 +00:00
virtual bool updateObject(const ObjectId id, const ObjectShapes& shapes, const btTransform& transform) = 0;
2018-07-12 08:44:11 +00:00
2018-09-29 22:20:42 +00:00
/**
* @brief updateObject replace object geometry by given data.
* @param id is used to find object.
* @param shape members must live until object is updated by another shape removed from Navigator.
* @param transform allows to setup objects geometry according to its world state.
* @return true if object is updated, false if there is no object with given id.
*/
2019-02-16 12:27:02 +00:00
virtual bool updateObject(const ObjectId id, const DoorShapes& shapes, const btTransform& transform) = 0;
2018-09-29 22:20:42 +00:00
/**
* @brief removeObject to make it no more available at the scene.
* @param id is used to find object.
* @return true if object is removed, false if there is no object with given id.
*/
2019-02-16 12:27:02 +00:00
virtual bool removeObject(const ObjectId id) = 0;
2018-03-13 22:49:08 +00:00
2018-09-29 22:20:42 +00:00
/**
* @brief addWater is used to set water level at given world cell.
* @param cellPosition allows to distinguish cells if there is many in current world.
* @param cellSize set cell borders. std::numeric_limits<int>::max() disables cell borders.
* @param shift set global shift of cell center.
2018-09-29 22:20:42 +00:00
* @return true if there was no water at given cell if cellSize != std::numeric_limits<int>::max() or there is
* at least single object is added to the scene, false if there is already water for given cell or there is no
* any other objects.
*/
2021-11-04 01:48:32 +00:00
virtual bool addWater(const osg::Vec2i& cellPosition, int cellSize, float level) = 0;
2018-07-20 19:11:34 +00:00
2018-09-29 22:20:42 +00:00
/**
* @brief removeWater to make it no more available at the scene.
* @param cellPosition allows to find cell.
* @return true if there was water at given cell.
*/
2019-02-16 12:27:02 +00:00
virtual bool removeWater(const osg::Vec2i& cellPosition) = 0;
2018-07-20 19:11:34 +00:00
2021-11-04 02:19:41 +00:00
virtual bool addHeightfield(const osg::Vec2i& cellPosition, int cellSize, const HeightfieldShape& shape) = 0;
virtual bool removeHeightfield(const osg::Vec2i& cellPosition) = 0;
virtual void addPathgrid(const ESM::Cell& cell, const ESM::Pathgrid& pathgrid) = 0;
virtual void removePathgrid(const ESM::Pathgrid& pathgrid) = 0;
2018-09-29 22:20:42 +00:00
/**
* @brief update starts background navmesh update using current scene state.
2018-09-29 22:20:42 +00:00
* @param playerPosition setup initial point to order build tiles of navmesh.
*/
2019-02-16 12:27:02 +00:00
virtual void update(const osg::Vec3f& playerPosition) = 0;
2018-03-13 22:49:08 +00:00
/**
* @brief updatePlayerPosition starts background navmesh update using current scene state only when player position has been changed.
* @param playerPosition setup initial point to order build tiles of navmesh.
*/
virtual void updatePlayerPosition(const osg::Vec3f& playerPosition) = 0;
/**
* @brief disable navigator updates
*/
virtual void setUpdatesEnabled(bool enabled) = 0;
2018-09-29 22:20:42 +00:00
/**
* @brief wait locks thread until tiles are updated from last update call based on passed condition type.
* @param waitConditionType defines when waiting will stop
2018-09-29 22:20:42 +00:00
*/
virtual void wait(Loading::Listener& listener, WaitConditionType waitConditionType) = 0;
2018-03-13 22:49:08 +00:00
/**
* @brief getNavMesh returns navmesh for specific agent half extents
* @return navmesh
*/
2019-02-16 12:27:02 +00:00
virtual SharedNavMeshCacheItem getNavMesh(const osg::Vec3f& agentHalfExtents) const = 0;
2018-09-29 22:20:42 +00:00
/**
* @brief getNavMeshes returns all current navmeshes
* @return map of agent half extents to navmesh
*/
2019-02-16 12:27:02 +00:00
virtual std::map<osg::Vec3f, SharedNavMeshCacheItem> getNavMeshes() const = 0;
2018-07-12 08:44:11 +00:00
virtual const Settings& getSettings() const = 0;
2019-03-17 17:18:53 +00:00
virtual void reportStats(unsigned int frameNumber, osg::Stats& stats) const = 0;
virtual RecastMeshTiles getRecastMeshTiles() const = 0;
virtual float getMaxNavmeshAreaRealRadius() const = 0;
2018-03-13 22:49:08 +00:00
};
std::unique_ptr<Navigator> makeNavigator(const Settings& settings, const std::string& userDataPath);
std::unique_ptr<Navigator> makeNavigatorStub();
2018-03-13 22:49:08 +00:00
}
#endif