119 lines
2.1 KiB
C
119 lines
2.1 KiB
C
/*
|
|
* Copyright 2011-2014 hasufell
|
|
*
|
|
* This file is part of a hasufell project.
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation version 2 of the License only.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef _DROW_ENGINE_TYPES_H
|
|
#define _DROW_ENGINE_TYPES_H
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
/**
|
|
* Standard file buffer
|
|
*/
|
|
#define STD_FILE_BUF 4096
|
|
|
|
typedef unsigned int** FACE;
|
|
|
|
typedef struct HE_edge HE_edge;
|
|
typedef struct HE_vert HE_vert;
|
|
typedef struct HE_face HE_face;
|
|
typedef struct HE_obj HE_obj;
|
|
|
|
/**
|
|
* Represents a half-edge.
|
|
*/
|
|
struct HE_edge {
|
|
/**
|
|
* Start-vertex of the halfe-edge.
|
|
*/
|
|
HE_vert *vert;
|
|
/**
|
|
* Oppositely oriented adjacent half-edge.
|
|
*/
|
|
HE_edge *pair;
|
|
/**
|
|
* Face the half-edge borders.
|
|
*/
|
|
HE_face *face;
|
|
/**
|
|
* Next half-edge around the face.
|
|
*/
|
|
HE_edge *next;
|
|
};
|
|
|
|
/**
|
|
* Represents a vertex with a random attached
|
|
* hald-edge.
|
|
*/
|
|
struct HE_vert {
|
|
float x;
|
|
float y;
|
|
float z;
|
|
|
|
/**
|
|
* One of the half-edges emanating from the vertex.
|
|
*/
|
|
HE_edge *edge;
|
|
};
|
|
|
|
/**
|
|
* Represents a face
|
|
*/
|
|
struct HE_face {
|
|
/**
|
|
* One of the half-edges bordering the face.
|
|
*/
|
|
HE_edge *edge;
|
|
};
|
|
|
|
/**
|
|
* Represents a collection of HE_edge, HE_vert and HE_face
|
|
* which are all attached to one object. This is useful
|
|
* for algorithms that need to iterate over one or another.
|
|
*/
|
|
struct HE_obj {
|
|
/**
|
|
* Array of edges.
|
|
*/
|
|
HE_edge *edges;
|
|
/**
|
|
* Array of vertices.
|
|
*/
|
|
HE_vert *vertices;
|
|
/**
|
|
* Array of faces.
|
|
*/
|
|
HE_face *faces;
|
|
/**
|
|
* Count of edges.
|
|
*/
|
|
uint8_t ec;
|
|
/**
|
|
* Count of vertices.
|
|
*/
|
|
uint8_t vc;
|
|
/**
|
|
* Count of faces.
|
|
*/
|
|
uint8_t fc;
|
|
};
|
|
|
|
|
|
#endif /* _DROW_ENGINE_TYPES_H */
|