2018-03-13 22:49:08 +00:00
|
|
|
#ifndef OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_H
|
|
|
|
#define OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_H
|
|
|
|
|
|
|
|
#include "tilebounds.hpp"
|
2020-01-28 21:24:51 +00:00
|
|
|
#include "status.hpp"
|
2021-11-05 22:48:48 +00:00
|
|
|
#include "recastmesh.hpp"
|
2018-03-13 22:49:08 +00:00
|
|
|
|
2018-10-31 15:15:01 +00:00
|
|
|
#include <osg/io_utils>
|
|
|
|
|
2018-03-13 22:49:08 +00:00
|
|
|
#include <components/bullethelpers/operators.hpp>
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
class dtNavMesh;
|
|
|
|
|
|
|
|
namespace DetourNavigator
|
|
|
|
{
|
|
|
|
inline std::ostream& operator <<(std::ostream& stream, const TileBounds& value)
|
|
|
|
{
|
|
|
|
return stream << "TileBounds {" << value.mMin << ", " << value.mMax << "}";
|
|
|
|
}
|
|
|
|
|
2020-01-28 21:24:51 +00:00
|
|
|
inline std::ostream& operator <<(std::ostream& stream, Status value)
|
|
|
|
{
|
|
|
|
#define OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(name) \
|
|
|
|
case Status::name: return stream << "DetourNavigator::Status::"#name;
|
|
|
|
switch (value)
|
|
|
|
{
|
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(Success)
|
2021-08-18 20:46:14 +00:00
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(PartialPath)
|
2020-01-28 21:24:51 +00:00
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(NavMeshNotFound)
|
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(StartPolygonNotFound)
|
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(EndPolygonNotFound)
|
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(MoveAlongSurfaceFailed)
|
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(FindPathOverPolygonsFailed)
|
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(GetPolyHeightFailed)
|
|
|
|
OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE(InitNavMeshQueryFailed)
|
|
|
|
}
|
|
|
|
#undef OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_STATUS_MESSAGE
|
|
|
|
return stream << "DetourNavigator::Error::" << static_cast<int>(value);
|
|
|
|
}
|
|
|
|
|
2021-11-05 22:48:48 +00:00
|
|
|
inline std::ostream& operator<<(std::ostream& s, const Water& v)
|
|
|
|
{
|
|
|
|
return s << "Water {" << v.mCellSize << ", " << v.mLevel << "}";
|
|
|
|
}
|
|
|
|
|
|
|
|
inline std::ostream& operator<<(std::ostream& s, const CellWater& v)
|
|
|
|
{
|
|
|
|
return s << "CellWater {" << v.mCellPosition << ", " << v.mWater << "}";
|
|
|
|
}
|
|
|
|
|
|
|
|
inline std::ostream& operator<<(std::ostream& s, const FlatHeightfield& v)
|
|
|
|
{
|
|
|
|
return s << "FlatHeightfield {" << v.mCellPosition << ", " << v.mCellSize << ", " << v.mHeight << "}";
|
|
|
|
}
|
|
|
|
|
|
|
|
inline std::ostream& operator<<(std::ostream& s, const Heightfield& v)
|
|
|
|
{
|
|
|
|
s << "Heightfield {.mCellPosition=" << v.mCellPosition
|
|
|
|
<< ", .mCellSize=" << v.mCellSize
|
|
|
|
<< ", .mLength=" << static_cast<int>(v.mLength)
|
|
|
|
<< ", .mMinHeight=" << v.mMinHeight
|
|
|
|
<< ", .mMaxHeight=" << v.mMaxHeight
|
|
|
|
<< ", .mHeights={";
|
|
|
|
for (float h : v.mHeights)
|
|
|
|
s << h << ", ";
|
|
|
|
s << "}";
|
|
|
|
return s << ", .mOriginalSize=" << v.mOriginalSize << "}";
|
|
|
|
}
|
|
|
|
|
2018-03-13 22:49:08 +00:00
|
|
|
class RecastMesh;
|
2021-11-06 12:46:43 +00:00
|
|
|
struct RecastSettings;
|
2018-03-13 22:49:08 +00:00
|
|
|
|
2021-11-06 12:46:43 +00:00
|
|
|
void writeToFile(const RecastMesh& recastMesh, const std::string& pathPrefix,
|
|
|
|
const std::string& revision, const RecastSettings& settings);
|
2018-04-01 15:09:43 +00:00
|
|
|
void writeToFile(const dtNavMesh& navMesh, const std::string& pathPrefix, const std::string& revision);
|
2018-03-13 22:49:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|