New files from new booleans
[blender.git] / intern / boolop / intern / BOP_Merge.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_MERGE_H
32 #define BOP_MERGE_H
33
34 #include "BOP_Mesh.h"
35 #include "BOP_Tag.h"
36 #include "BOP_MathUtils.h"
37 #include "MEM_SmartPtr.h"
38
39 typedef vector< BOP_Faces > BOP_LFaces;
40 typedef vector< BOP_Faces >::iterator BOP_IT_LFaces;
41
42 class BOP_Merge {
43         private:
44                 BOP_Mesh* m_mesh;
45                 BOP_Index m_firstVertex;
46                 static BOP_Merge SINGLETON;
47
48                 BOP_Merge() {};
49                 bool mergeFaces();
50                 bool mergeFaces(BOP_Indexs &mergeVertices);
51                 bool mergeFaces(BOP_Faces &oldFaces, BOP_Faces &newFaces, BOP_Indexs &vertices, BOP_Index v);
52                 bool mergeFaces(BOP_Faces &faces, BOP_Faces &oldFaces, BOP_Faces &newFaces, BOP_Indexs &vertices, BOP_Index v);
53                 BOP_Face *mergeFaces(BOP_Face *faceI, BOP_Face *faceJ, BOP_Index v);
54                 BOP_Face *mergeFaces(BOP_Face *faceI, BOP_Face *faceJ, BOP_Indexs &pending, BOP_Index v);
55                 BOP_Face *mergeFaces(BOP_Face3 *faceI, BOP_Face3 *faceJ, BOP_Index v);
56                 BOP_Face *mergeFaces(BOP_Face4 *faceI, BOP_Face3 *faceJ, BOP_Index v);
57                 BOP_Face *mergeFaces(BOP_Face4 *faceI, BOP_Face3 *faceJ, BOP_Indexs &pending, BOP_Index v);
58                 BOP_Face *mergeFaces(BOP_Face4 *faceI, BOP_Face4 *faceJ, BOP_Indexs &pending, BOP_Index v);
59                 bool createQuads();
60                 BOP_Face *createQuad(BOP_Face3 *faceI, BOP_Face3 *faceJ, BOP_Index v);
61                 bool containsIndex(BOP_Indexs indexs, BOP_Index index);
62                 void getFaces(BOP_LFaces &facesByOriginalFace, BOP_Index v);
63                 void getFaces(BOP_LFaces &facesByOriginalFace, BOP_Indexs vertices, BOP_Index v);
64
65         public:
66
67                 static BOP_Merge &getInstance() {
68                         return SINGLETON;
69                 }
70
71                 void mergeFaces(BOP_Mesh *m, BOP_Index v);
72 };
73
74 #endif