leocad/common/lc_mesh.h

121 lines
2.4 KiB
C
Raw Normal View History

2013-08-09 04:57:18 +00:00
#ifndef _LC_MESH_H_
#define _LC_MESH_H_
#include "lc_math.h"
#define LC_MESH_FILE_ID LC_FOURCC('M', 'E', 'S', 'H')
2017-04-01 16:53:54 -07:00
#define LC_MESH_FILE_VERSION 0x0113
2016-08-22 01:11:32 +00:00
enum lcMeshPrimitiveType
{
2017-04-01 16:53:54 -07:00
LC_MESH_LINES = 0x01,
LC_MESH_TRIANGLES = 0x02,
LC_MESH_TEXTURED_LINES = 0x04,
LC_MESH_TEXTURED_TRIANGLES = 0x08,
LC_MESH_CONDITIONAL_LINES = 0x10,
2016-08-22 01:11:32 +00:00
LC_MESH_NUM_PRIMITIVE_TYPES
};
2013-08-09 04:57:18 +00:00
struct lcVertex
{
lcVector3 Position;
2017-02-18 11:12:35 -08:00
quint32 Normal;
2013-08-09 04:57:18 +00:00
};
struct lcVertexTextured
{
lcVector3 Position;
2017-02-18 11:12:35 -08:00
quint32 Normal;
2013-08-09 04:57:18 +00:00
lcVector2 TexCoord;
};
struct lcMeshSection
{
int ColorIndex;
int IndexOffset;
int NumIndices;
2016-08-22 01:11:32 +00:00
lcMeshPrimitiveType PrimitiveType;
2013-08-09 04:57:18 +00:00
lcTexture* Texture;
};
2015-05-24 04:36:25 +00:00
struct lcMeshLod
{
lcMeshSection* Sections;
int NumSections;
};
enum
{
LC_MESH_LOD_HIGH,
LC_MESH_LOD_LOW,
LC_NUM_MESH_LODS
};
2013-08-09 04:57:18 +00:00
class lcMesh
{
public:
lcMesh();
~lcMesh();
2015-05-24 04:36:25 +00:00
void Create(lcuint16 NumSections[LC_NUM_MESH_LODS], int NumVertices, int NumTexturedVertices, int NumIndices);
2013-08-09 04:57:18 +00:00
void CreateBox();
bool FileLoad(lcMemFile& File);
bool FileSave(lcMemFile& File);
2013-08-09 04:57:18 +00:00
template<typename IndexType>
void ExportPOVRay(lcFile& File, const char* MeshName, const char** ColorTable);
void ExportPOVRay(lcFile& File, const char* MeshName, const char** ColorTable);
2013-08-09 04:57:18 +00:00
template<typename IndexType>
void ExportWavefrontIndices(lcFile& File, int DefaultColorIndex, int VertexOffset);
void ExportWavefrontIndices(lcFile& File, int DefaultColorIndex, int VertexOffset);
template<typename IndexType>
bool MinIntersectDist(const lcVector3& Start, const lcVector3& End, float& MinDist);
bool MinIntersectDist(const lcVector3& Start, const lcVector3& End, float& MinDist);
2013-08-09 04:57:18 +00:00
template<typename IndexType>
bool IntersectsPlanes(const lcVector4 Planes[6]);
bool IntersectsPlanes(const lcVector4 Planes[6]);
2015-05-24 04:36:25 +00:00
int GetLodIndex(float Distance) const;
lcMeshLod mLods[LC_NUM_MESH_LODS];
2016-02-19 17:53:54 +00:00
lcBoundingBox mBoundingBox;
2015-05-24 04:36:25 +00:00
float mRadius;
2013-08-09 04:57:18 +00:00
void* mVertexData;
int mVertexDataSize;
void* mIndexData;
int mIndexDataSize;
int mVertexCacheOffset;
int mIndexCacheOffset;
2013-08-09 04:57:18 +00:00
int mNumVertices;
int mNumTexturedVertices;
int mIndexType;
};
2015-05-04 00:51:41 +00:00
enum lcRenderMeshState
{
LC_RENDERMESH_NONE,
LC_RENDERMESH_SELECTED,
LC_RENDERMESH_FOCUSED,
LC_RENDERMESH_HIGHLIGHT
2015-05-04 00:51:41 +00:00
};
2014-04-20 01:50:41 +00:00
struct lcRenderMesh
{
2014-12-24 15:52:52 +00:00
lcMatrix44 WorldMatrix;
2014-04-20 01:50:41 +00:00
lcMesh* Mesh;
float Distance;
2015-02-08 18:54:51 +00:00
int ColorIndex;
2015-05-24 04:36:25 +00:00
int LodIndex;
2015-05-04 00:51:41 +00:00
lcRenderMeshState State;
2014-04-20 01:50:41 +00:00
};
extern lcMesh* gPlaceholderMesh;
2013-08-09 04:57:18 +00:00
#endif // _LC_MESH_H_