metaforce/Runtime/Collision/COBBTree.hpp

95 lines
3.2 KiB
C++
Raw Normal View History

2016-04-26 10:40:56 +00:00
#ifndef __URDE_COBBTREE_HPP__
#define __URDE_COBBTREE_HPP__
#include "RetroTypes.hpp"
#include "CCollisionEdge.hpp"
2016-07-28 06:37:50 +00:00
#include "CCollisionSurface.hpp"
2016-04-26 10:40:56 +00:00
#include "zeus/CVector3f.hpp"
#include "zeus/COBBox.hpp"
namespace urde
{
2017-07-03 03:34:19 +00:00
class CCollidableOBBTreeGroupContainer;
2016-04-26 10:40:56 +00:00
class COBBTree
{
public:
struct SIndexData
{
2016-07-28 06:37:50 +00:00
std::vector<u32> x0_materials;
std::vector<u8> x10_vertMaterials;
std::vector<u8> x20_edgeMaterials;
std::vector<u8> x30_surfaceMaterials;
std::vector<CCollisionEdge> x40_edges;
std::vector<u16> x50_surfaceIndices;
std::vector<zeus::CVector3f> x60_vertices;
2016-04-26 10:40:56 +00:00
SIndexData()=default;
SIndexData(CInputStream&);
};
2016-04-27 00:26:02 +00:00
class CLeafData
2016-04-26 10:40:56 +00:00
{
2016-04-27 00:26:02 +00:00
std::vector<u16> x0_surface;
public:
CLeafData()=default;
CLeafData(const std::vector<u16>&);
CLeafData(CInputStream&);
const std::vector<u16>& GetSurfaceVector() const;
2016-06-24 20:09:38 +00:00
size_t GetMemoryUsage() const;
2016-04-26 10:40:56 +00:00
};
class CNode
{
zeus::COBBox x0_obb;
2016-04-27 00:26:02 +00:00
bool x3c_isLeaf = false;
std::unique_ptr<CNode> x40_left;
std::unique_ptr<CNode> x44_right;
std::unique_ptr<CLeafData> x48_leaf;
2017-07-03 03:34:19 +00:00
bool x4c_hit;
2016-04-26 10:40:56 +00:00
public:
CNode() = default;
2016-04-27 00:26:02 +00:00
CNode(const CNode&)=default;
CNode(const zeus::CTransform&, const zeus::CVector3f&, const CNode*, const CNode*, const CLeafData*);
2016-04-26 10:40:56 +00:00
CNode(CInputStream&);
2016-04-27 00:26:02 +00:00
2017-07-03 03:34:19 +00:00
bool WasHit() const { return x4c_hit; }
void SetHit(bool h) { x4c_hit = h; }
const CNode& GetLeft() const { return *x40_left; }
const CNode& GetRight() const { return *x44_right; }
const CLeafData& GetLeafData() const { return *x48_leaf; }
const zeus::COBBox& GetOBB() const { return x0_obb; }
2016-06-24 20:09:38 +00:00
size_t GetMemoryUsage() const;
2017-07-03 03:34:19 +00:00
bool IsLeaf() const { return x3c_isLeaf; }
2016-04-26 10:40:56 +00:00
};
private:
u32 x0_magic = 0;
u32 x4_version = 0;
u32 x8_memsize = 0;
/* CSimpleAllocator xc_ We're not using this but lets keep track*/
SIndexData x18_indexData;
2016-04-27 02:41:00 +00:00
std::unique_ptr<CNode> x88_root;
2016-04-26 10:40:56 +00:00
public:
2016-04-27 00:26:02 +00:00
COBBTree()=default;
2016-04-26 10:40:56 +00:00
COBBTree(const COBBTree::SIndexData&, const CNode*);
COBBTree(CInputStream&);
2016-04-27 02:41:00 +00:00
2017-07-03 03:34:19 +00:00
static std::unique_ptr<CCollidableOBBTreeGroupContainer>
BuildOrientedBoundingBoxTree(const zeus::CVector3f&, const zeus::CVector3f&);
CCollisionSurface GetSurface(u16 idx) const;
const u16* GetTriangleEdgeIndices(u16 idx) const { return &x18_indexData.x50_surfaceIndices[idx * 3]; }
void GetTriangleVertexIndices(u16 idx, u16 indicesOut[3]) const;
const CCollisionEdge& GetEdge(int idx) const { return x18_indexData.x40_edges[idx]; }
const zeus::CVector3f& GetVert(int idx) const { return x18_indexData.x60_vertices[idx]; }
u32 GetVertMaterial(u16 idx) const { return x18_indexData.x0_materials[x18_indexData.x10_vertMaterials[idx]]; }
u32 GetEdgeMaterial(u16 idx) const { return x18_indexData.x0_materials[x18_indexData.x20_edgeMaterials[idx]]; }
CCollisionSurface GetTransformedSurface(u16 idx, const zeus::CTransform& xf) const;
2016-04-27 02:41:00 +00:00
zeus::CAABox CalculateLocalAABox() const;
zeus::CAABox CalculateAABox(const zeus::CTransform&) const;
2017-07-03 03:34:19 +00:00
const CNode& GetRoot() const { return *x88_root; }
2016-04-26 10:40:56 +00:00
};
}
#endif // __URDE_COBBTREE_HPP__