You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
2.3 KiB
74 lines
2.3 KiB
5 years ago
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||
|
//
|
||
|
// Purpose:
|
||
|
//
|
||
|
// $NoKeywords: $
|
||
|
//
|
||
|
//=============================================================================//
|
||
|
|
||
|
#ifndef POLYHEDRON_H_
|
||
|
#define POLYHEDRON_H_
|
||
|
|
||
|
#ifdef _WIN32
|
||
|
#pragma once
|
||
|
#endif
|
||
|
|
||
|
#include "mathlib/mathlib.h"
|
||
|
|
||
|
|
||
|
|
||
|
struct Polyhedron_IndexedLine_t
|
||
|
{
|
||
|
unsigned short iPointIndices[2];
|
||
|
};
|
||
|
|
||
|
struct Polyhedron_IndexedLineReference_t
|
||
|
{
|
||
|
unsigned short iLineIndex;
|
||
|
unsigned char iEndPointIndex; //since two polygons reference any one line, one needs to traverse the line backwards, this flags that behavior
|
||
|
};
|
||
|
|
||
|
struct Polyhedron_IndexedPolygon_t
|
||
|
{
|
||
|
unsigned short iFirstIndex;
|
||
|
unsigned short iIndexCount;
|
||
|
Vector polyNormal;
|
||
|
};
|
||
|
|
||
|
class CPolyhedron //made into a class because it's going virtual to support distinctions between temp and permanent versions
|
||
|
{
|
||
|
public:
|
||
|
Vector *pVertices;
|
||
|
Polyhedron_IndexedLine_t *pLines;
|
||
|
Polyhedron_IndexedLineReference_t *pIndices;
|
||
|
Polyhedron_IndexedPolygon_t *pPolygons;
|
||
|
|
||
|
unsigned short iVertexCount;
|
||
|
unsigned short iLineCount;
|
||
|
unsigned short iIndexCount;
|
||
|
unsigned short iPolygonCount;
|
||
|
|
||
|
virtual ~CPolyhedron( void ) {};
|
||
|
virtual void Release( void ) = 0;
|
||
|
Vector Center( void );
|
||
|
};
|
||
|
|
||
|
class CPolyhedron_AllocByNew : public CPolyhedron
|
||
|
{
|
||
|
public:
|
||
|
virtual void Release( void );
|
||
|
static CPolyhedron_AllocByNew *Allocate( unsigned short iVertices, unsigned short iLines, unsigned short iIndices, unsigned short iPolygons ); //creates the polyhedron along with enough memory to hold all it's data in a single allocation
|
||
|
|
||
|
private:
|
||
|
CPolyhedron_AllocByNew( void ) { }; //CPolyhedron_AllocByNew::Allocate() is the only way to create one of these.
|
||
|
};
|
||
|
|
||
|
CPolyhedron *GeneratePolyhedronFromPlanes( const float *pOutwardFacingPlanes, int iPlaneCount, float fOnPlaneEpsilon, bool bUseTemporaryMemory = false ); //be sure to polyhedron->Release()
|
||
|
CPolyhedron *ClipPolyhedron( const CPolyhedron *pExistingPolyhedron, const float *pOutwardFacingPlanes, int iPlaneCount, float fOnPlaneEpsilon, bool bUseTemporaryMemory = false ); //this does NOT modify/delete the existing polyhedron
|
||
|
|
||
|
CPolyhedron *GetTempPolyhedron( unsigned short iVertices, unsigned short iLines, unsigned short iIndices, unsigned short iPolygons ); //grab the temporary polyhedron. Avoids new/delete for quick work. Can only be in use by one chunk of code at a time
|
||
|
|
||
|
|
||
|
#endif //#ifndef POLYHEDRON_H_
|
||
|
|