mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-22 04:23:50 +00:00
3a2cea5271
Serialization into a vector of chars produces inconsistent results that leads to reduced cache hit rate. Using a structured object is a more clear solution and allows to remove serialization and nontrivial key compare logic with more straigt forward structured object comparison.
106 lines
2.5 KiB
C++
106 lines
2.5 KiB
C++
#ifndef OPENMW_COMPONENTS_DETOURNAVIGATOR_RECASTMESH_H
|
|
#define OPENMW_COMPONENTS_DETOURNAVIGATOR_RECASTMESH_H
|
|
|
|
#include "areatype.hpp"
|
|
#include "chunkytrimesh.hpp"
|
|
#include "bounds.hpp"
|
|
|
|
#include <components/bullethelpers/operators.hpp>
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
#include <vector>
|
|
#include <tuple>
|
|
|
|
#include <osg/Vec3f>
|
|
|
|
#include <LinearMath/btTransform.h>
|
|
|
|
namespace DetourNavigator
|
|
{
|
|
class RecastMesh
|
|
{
|
|
public:
|
|
struct Water
|
|
{
|
|
int mCellSize;
|
|
btTransform mTransform;
|
|
};
|
|
|
|
RecastMesh(std::size_t generation, std::size_t revision, std::vector<int> indices, std::vector<float> vertices,
|
|
std::vector<AreaType> areaTypes, std::vector<Water> water, const std::size_t trianglesPerChunk);
|
|
|
|
std::size_t getGeneration() const
|
|
{
|
|
return mGeneration;
|
|
}
|
|
|
|
std::size_t getRevision() const
|
|
{
|
|
return mRevision;
|
|
}
|
|
|
|
const std::vector<int>& getIndices() const
|
|
{
|
|
return mIndices;
|
|
}
|
|
|
|
const std::vector<float>& getVertices() const
|
|
{
|
|
return mVertices;
|
|
}
|
|
|
|
const std::vector<AreaType>& getAreaTypes() const
|
|
{
|
|
return mAreaTypes;
|
|
}
|
|
|
|
const std::vector<Water>& getWater() const
|
|
{
|
|
return mWater;
|
|
}
|
|
|
|
std::size_t getVerticesCount() const
|
|
{
|
|
return mVertices.size() / 3;
|
|
}
|
|
|
|
std::size_t getTrianglesCount() const
|
|
{
|
|
return mIndices.size() / 3;
|
|
}
|
|
|
|
const ChunkyTriMesh& getChunkyTriMesh() const
|
|
{
|
|
return mChunkyTriMesh;
|
|
}
|
|
|
|
const Bounds& getBounds() const
|
|
{
|
|
return mBounds;
|
|
}
|
|
|
|
private:
|
|
std::size_t mGeneration;
|
|
std::size_t mRevision;
|
|
std::vector<int> mIndices;
|
|
std::vector<float> mVertices;
|
|
std::vector<AreaType> mAreaTypes;
|
|
std::vector<Water> mWater;
|
|
ChunkyTriMesh mChunkyTriMesh;
|
|
Bounds mBounds;
|
|
};
|
|
|
|
inline bool operator<(const RecastMesh::Water& lhs, const RecastMesh::Water& rhs)
|
|
{
|
|
return std::tie(lhs.mCellSize, lhs.mTransform) < std::tie(rhs.mCellSize, rhs.mTransform);
|
|
}
|
|
|
|
inline bool operator <(const RecastMesh& lhs, const RecastMesh& rhs)
|
|
{
|
|
return std::tie(lhs.getIndices(), lhs.getVertices(), lhs.getAreaTypes(), lhs.getWater())
|
|
< std::tie(rhs.getIndices(), rhs.getVertices(), rhs.getAreaTypes(), rhs.getWater());
|
|
}
|
|
}
|
|
|
|
#endif
|