New files from new booleans
[blender.git] / intern / boolop / intern / BOP_Mesh.h
1 /**
2  * ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version. The Blender
8  * Foundation also sells licenses for use in proprietary software under
9  * the Blender License.  See http://www.blender.org/BL/ for information
10  * about this.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software Foundation,
19  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
20  *
21  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
22  * All rights reserved.
23  *
24  * The Original Code is: all of this file.
25  *
26  * Contributor(s): none yet.
27  *
28  * ***** END GPL/BL DUAL LICENSE BLOCK *****
29  */
30  
31 #ifndef BOP_MESH_H
32 #define BOP_MESH_H
33
34 #include "BOP_Vertex.h"
35 #include "BOP_Edge.h"
36 #include "BOP_Face.h"
37
38 typedef vector<BOP_Vertex *> BOP_Vertexs;
39 typedef vector<BOP_Edge *> BOP_Edges;
40
41 typedef vector<BOP_Vertex *>::iterator BOP_IT_Vertexs;
42 typedef vector<BOP_Edge *>::iterator BOP_IT_Edges;
43
44 class BOP_Mesh
45 {
46 private:
47         BOP_Vertexs m_vertexs;
48         BOP_Edges   m_edges;
49         BOP_Faces   m_faces;
50         
51         BOP_Index addEdge(BOP_Index v1, BOP_Index v2);
52         BOP_Edge *getEdge(BOP_Indexs edges, BOP_Index v2);    
53         bool containsFace(BOP_Faces *faces, BOP_Face *face);
54
55         bool testEdges(BOP_Faces *faces);
56         bool testFaces(BOP_Face *faceI, BOP_Face *faceJ);
57         bool testFace(BOP_Face *face);
58
59 public:
60         ~BOP_Mesh();
61         
62         BOP_Index addVertex(MT_Point3 point);
63         BOP_Index addFace(BOP_Face *face);
64         BOP_Index addFace(BOP_Face3 *face);
65         BOP_Index addFace(BOP_Face4 *face);
66         BOP_Vertex* getVertex(BOP_Index v);
67         BOP_Face*getFace(BOP_Index v);
68         BOP_Edge* getEdge(BOP_Index v);
69         BOP_Edge* getEdge(BOP_Face * face, unsigned int edge);            
70         BOP_Edge* getEdge(BOP_Face3 * face, unsigned int edge);            
71         BOP_Edge* getEdge(BOP_Face4 * face, unsigned int edge);            
72         BOP_Edge* getEdge(BOP_Index v1, BOP_Index v2);
73         bool getIndexEdge(BOP_Index v1, BOP_Index v2, BOP_Index &e);
74         BOP_Vertexs &getVertexs();
75         BOP_Edges &getEdges();
76         BOP_Faces &getFaces();
77         BOP_Face* getFace(BOP_Index v1, BOP_Index v2, BOP_Index v3);
78         bool getIndexFace(BOP_Index v1, BOP_Index v2, BOP_Index v3, BOP_Index &f);
79         unsigned int getNumVertexs();
80         unsigned int getNumEdges();
81         unsigned int getNumFaces();
82         unsigned int getNumVertexs(BOP_TAG tag);
83         unsigned int getNumFaces(BOP_TAG tag);
84         BOP_Index replaceVertexIndex(BOP_Index oldIndex, BOP_Index newIndex);
85         
86         // Debug functions
87         void print();
88         void printFormat();
89         void printFormat(BOP_Faces *faces);
90         void saveFormat(BOP_Faces *faces, char *filename);
91         void printFace(BOP_Face *face, int col = 0);
92         void testPlane(BOP_Face *face);
93         void testMesh();
94         void updatePlanes();
95 };
96
97 #endif