Merged changes in the trunk up to revision 46045.
[blender.git] / source / blender / blenkernel / BKE_subsurf.h
1 /*
2  * ***** BEGIN GPL 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.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
19  * All rights reserved.
20  *
21  * The Original Code is: all of this file.
22  *
23  * Contributor(s): none yet.
24  *
25  * ***** END GPL LICENSE BLOCK *****
26  */
27 #ifndef __BKE_SUBSURF_H__
28 #define __BKE_SUBSURF_H__
29
30 /** \file BKE_subsurf.h
31  *  \ingroup bke
32  */
33
34 /* struct DerivedMesh is used directly */
35 #include "BKE_DerivedMesh.h"
36
37 struct DMFlagMat;
38 struct DMGridAdjacency;
39 struct DMGridData;
40 struct DerivedMesh;
41 struct MeshElemMap;
42 struct Mesh;
43 struct MPoly;
44 struct MultiresSubsurf;
45 struct Object;
46 struct PBVH;
47 struct SubsurfModifierData;
48 struct CCGEdge;
49 struct CCGFace;
50 struct CCGSubsurf;
51 struct CCGVert;
52 struct EdgeHash;
53 struct PBVH;
54 struct DMGridData;
55 struct DMGridAdjacency;
56
57 /**************************** External *****************************/
58
59 struct DerivedMesh *subsurf_make_derived_from_derived(
60                                                 struct DerivedMesh *dm,
61                                                 struct SubsurfModifierData *smd,
62                                                 int useRenderParams, float (*vertCos)[3],
63                                                 int isFinalCalc, int forEditMode, int inEditMode);
64
65 void subsurf_calculate_limit_positions(struct Mesh *me, float (*positions_r)[3]);
66
67 /* get gridsize from 'level', level must be greater than zero */
68 int ccg_gridsize(int level);
69
70 /* x/y grid coordinates at 'low_level' can be multiplied by the result
71  * of this function to convert to grid coordinates at 'high_level' */
72 int ccg_factor(int low_level, int high_level);
73
74 void subsurf_copy_grid_hidden(struct DerivedMesh *dm,
75                                                           const struct MPoly *mpoly,
76                                                           struct MVert *mvert,
77                                                           const struct MDisps *mdisps);
78
79 typedef enum MultiresModifiedFlags {
80         /* indicates the grids have been sculpted on, so MDisps
81          * have to be updated */
82         MULTIRES_COORDS_MODIFIED = 1,
83         /* indicates elements have been hidden or unhidden */
84         MULTIRES_HIDDEN_MODIFIED = 2
85 } MultiresModifiedFlags;
86
87 /**************************** Internal *****************************/
88
89 typedef struct CCGDerivedMesh {
90         DerivedMesh dm;
91
92         struct CCGSubSurf *ss;
93         int freeSS;
94         int drawInteriorEdges, useSubsurfUv;
95
96         struct {int startVert; struct CCGVert *vert;} *vertMap;
97         struct {int startVert; int startEdge; struct CCGEdge *edge;} *edgeMap;
98         struct {int startVert; int startEdge;
99                         int startFace; struct CCGFace *face;} *faceMap;
100
101         short *edgeFlags;
102         struct DMFlagMat *faceFlags;
103
104         int *reverseFaceMap;
105
106         struct PBVH *pbvh;
107
108         struct MeshElemMap *pmap;
109         int *pmap_mem;
110
111         struct DMGridData **gridData;
112         struct DMGridAdjacency *gridAdjacency;
113         int *gridOffset;
114         struct CCGFace **gridFaces;
115         struct DMFlagMat *gridFlagMats;
116         unsigned int **gridHidden;
117
118         struct {
119                 struct MultiresModifierData *mmd;
120                 int local_mmd;
121
122                 int lvl, totlvl;
123                 float (*orco)[3];
124
125                 struct Object *ob;
126                 MultiresModifiedFlags modified_flags;
127         } multires;
128
129         struct EdgeHash *ehash;
130 } CCGDerivedMesh;
131
132 #endif
133