Code Cleanup:
[blender-staging.git] / source / blender / editors / mesh / mesh_intern.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
28 /** \file blender/editors/mesh/mesh_intern.h
29  *  \ingroup edmesh
30  */
31
32
33 /* Internal for editmesh_xxxx.c functions */
34
35 #ifndef MESH_INTERN_H
36 #define MESH_INTERN_H
37
38 #include "DNA_scene_types.h"
39 #include "DNA_object_types.h"
40 #include "DNA_mesh_types.h"
41
42 #include "BKE_tessmesh.h"
43
44 #include "BLI_editVert.h"
45
46 #include "RNA_types.h"
47
48 struct bContext;
49 struct wmOperatorType;
50 struct ViewContext;
51 struct BMEditMesh;
52 struct BMesh;
53 struct BMEdge;
54 struct BMFace;
55 struct wmOperator;
56 struct wmKeyMap;
57 struct wmKeyConfig;
58
59 /* ******************** bmeshutils.c */
60
61 /*
62 ok: the EDBM module is for editmode bmesh stuff.  in contrast, the 
63     BMEdit module is for code shared with blenkernel that concerns
64     the BMEditMesh structure.
65 */
66
67 /*calls a bmesh op, reporting errors to the user, etc*/
68 int EDBM_CallOpf(struct BMEditMesh *em, struct wmOperator *op, const char *fmt, ...);
69
70 /*calls a bmesh op, reporting errors to the user, etc.
71
72   selects an output slot specified by selslot*/
73 //int EDBM_CallAndSelectOpf(struct BMEditMesh *em, struct wmOperator *op, char *selslot, char *fmt, ...);
74 //moved to ED_mesh.h
75
76 /*same as above, but doesn't report errors.*/
77 int EDBM_CallOpfSilent(struct BMEditMesh *em, const char *fmt, ...);
78
79 /*these next two functions are the split version of EDBM_CallOpf, so you can
80   do stuff with a bmesh operator, after initializing it but before executing
81   it.
82   
83   execute the operator with BM_Exec_Op*/
84 int EDBM_InitOpf(struct BMEditMesh *em, struct BMOperator *bmop,
85                  struct wmOperator *op, const char *fmt, ...);
86 /*cleans up after a bmesh operator*/
87 int EDBM_FinishOp(struct BMEditMesh *em, struct BMOperator *bmop,
88                   struct wmOperator *op, const int report);
89
90 void EDBM_clear_flag_all(struct BMEditMesh *em, const char hflag);
91 void EDBM_store_selection(struct BMEditMesh *em, void *data);
92 void EDBM_validate_selections(struct BMEditMesh *em);
93 void EDBM_remove_selection(struct BMEditMesh *em, void *data);
94 void EDBM_stats_update(struct BMEditMesh *em);
95
96 /* TODO, move to math_geometry.c */
97 float labda_PdistVL2Dfl(const float v1[3], const float v2[3], const float v3[3]);
98
99 /* ******************** editface.c */
100
101
102
103 /* ******************* editmesh.c */
104
105 extern void free_editvert(EditMesh *em, EditVert *eve);
106 extern void free_editedge(EditMesh *em, EditEdge *eed);
107 extern void free_editface(EditMesh *em, EditFace *efa);
108
109 /*frees dst mesh, then copies the contents of 
110   *src (the struct) to dst. */
111 void set_editMesh(EditMesh *dst, EditMesh *src);
112
113 extern void free_vertlist(EditMesh *em, ListBase *edve);
114 extern void free_edgelist(EditMesh *em, ListBase *lb);
115 extern void free_facelist(EditMesh *em, ListBase *lb);
116
117 extern void remedge(EditMesh *em, EditEdge *eed);
118
119 extern struct EditVert *addvertlist(EditMesh *em, float *vec, struct EditVert *example);
120 extern struct EditEdge *addedgelist(EditMesh *em, struct EditVert *v1, struct EditVert *v2, struct EditEdge *example);
121 extern struct EditFace *addfacelist(EditMesh *em, struct EditVert *v1, struct EditVert *v2, struct EditVert *v3, struct EditVert *v4, struct EditFace *example, struct EditFace *exampleEdges);
122 extern struct EditEdge *findedgelist(EditMesh *em, struct EditVert *v1, struct EditVert *v2);
123
124 void em_setup_viewcontext(struct bContext *C, struct ViewContext *vc);
125
126 void MESH_OT_separate(struct wmOperatorType *ot);
127
128 /* ******************* editmesh_add.c */
129 void MESH_OT_primitive_plane_add(struct wmOperatorType *ot);
130 void MESH_OT_primitive_cube_add(struct wmOperatorType *ot);
131 void MESH_OT_primitive_circle_add(struct wmOperatorType *ot);
132 void MESH_OT_primitive_cylinder_add(struct wmOperatorType *ot);
133 void MESH_OT_primitive_cone_add(struct wmOperatorType *ot);
134 void MESH_OT_primitive_grid_add(struct wmOperatorType *ot);
135 void MESH_OT_primitive_monkey_add(struct wmOperatorType *ot);
136 void MESH_OT_primitive_uv_sphere_add(struct wmOperatorType *ot);
137 void MESH_OT_primitive_ico_sphere_add(struct wmOperatorType *ot);
138
139 void MESH_OT_edge_face_add(struct wmOperatorType *ot);
140 void MESH_OT_dupli_extrude_cursor(struct wmOperatorType *ot);
141 void MESH_OT_duplicate(struct wmOperatorType *ot);
142
143 void MESH_OT_fgon_make(struct wmOperatorType *ot);
144 void MESH_OT_fgon_clear(struct wmOperatorType *ot);
145
146 /* ******************* editmesh_lib.c */
147 void EM_stats_update(EditMesh *em);
148
149 extern void EM_fgon_flags(EditMesh *em);
150 extern void EM_hide_reset(EditMesh *em);
151
152 extern int faceselectedOR(EditFace *efa, int flag);
153 extern int faceselectedAND(EditFace *efa, int flag);
154
155 void EM_remove_selection(EditMesh *em, void *data, int type);
156 void EM_clear_flag_all(EditMesh *em, int flag);
157 void EM_set_flag_all(EditMesh *em, int flag);
158 void EM_set_flag_all_selectmode(EditMesh *em, int flag);
159
160 void EM_data_interp_from_verts(EditMesh *em, EditVert *v1, EditVert *v2, EditVert *eve, float fac);
161 void EM_data_interp_from_faces(EditMesh *em, EditFace *efa1, EditFace *efa2, EditFace *efan, int i1, int i2, int i3, int i4);
162
163 int EM_nvertices_selected(EditMesh *em);
164 int EM_nedges_selected(EditMesh *em);
165 int EM_nfaces_selected(EditMesh *em);
166
167 float EM_face_perimeter(EditFace *efa);
168
169 void EM_store_selection(EditMesh *em, void *data, int type);
170
171 extern EditFace *exist_face(EditMesh *em, EditVert *v1, EditVert *v2, EditVert *v3, EditVert *v4);
172 extern void flipface(EditMesh *em, EditFace *efa); // flips for normal direction
173 extern int compareface(EditFace *vl1, EditFace *vl2);
174
175 /* flag for selection bits, *nor will be filled with normal for extrusion constraint */
176 /* return value defines if such normal was set */
177 extern short extrudeflag_face_indiv(EditMesh *em, short flag, float *nor);
178 extern short extrudeflag_verts_indiv(EditMesh *em, short flag, float *nor);
179 extern short extrudeflag_edges_indiv(EditMesh *em, short flag, float *nor);
180 extern short extrudeflag_vert(Object *obedit, EditMesh *em, short flag, float *nor, int all);
181 extern short extrudeflag(Object *obedit, EditMesh *em, short flag, float *nor, int all);
182
183 extern void adduplicateflag(EditMesh *em, int flag);
184 extern void delfaceflag(EditMesh *em, int flag);
185
186 extern void rotateflag(EditMesh *em, short flag, float *cent, float rotmat[][3]);
187 extern void translateflag(EditMesh *em, short flag, float *vec);
188
189 extern int convex(float *v1, float *v2, float *v3, float *v4);
190
191 extern struct EditFace *EM_face_from_faces(EditMesh *em, struct EditFace *efa1,
192                                                                                    struct EditFace *efa2, int i1, int i2, int i3, int i4);
193
194 extern int EM_view3d_poll(struct bContext *C);
195
196 struct wmKeyMap* knifetool_modal_keymap(struct wmKeyConfig *keyconf);
197
198 /* ******************* knifetool.c */
199
200 void MESH_OT_knife_cut(struct wmOperatorType *ot);
201
202 /* ******************* bmesh_select.c */
203 void MESH_OT_loop_select(struct wmOperatorType *ot);
204 void MESH_OT_select_all(struct wmOperatorType *ot);
205 void MESH_OT_bmesh_test(struct wmOperatorType *ot);
206 void MESH_OT_select_more(struct wmOperatorType *ot);
207 void MESH_OT_select_less(struct wmOperatorType *ot);
208 void MESH_OT_select_non_manifold(struct wmOperatorType *ot);
209 void MESH_OT_select_linked(struct wmOperatorType *ot);
210 void MESH_OT_select_linked_pick(struct wmOperatorType *ot);
211 void MESH_OT_hide(struct wmOperatorType *ot);
212 void MESH_OT_reveal(struct wmOperatorType *ot);
213 void MESH_OT_select_by_number_vertices(struct wmOperatorType *ot);
214 void MESH_OT_select_loose_verts(struct wmOperatorType *ot);
215 void MESH_OT_select_mirror(struct wmOperatorType *ot);
216 void MESH_OT_normals_make_consistent(struct wmOperatorType *ot);
217 void MESH_OT_faces_select_linked_flat(struct wmOperatorType *ot);
218 void MESH_OT_edges_select_sharp(struct wmOperatorType *ot);
219 void MESH_OT_select_shortest_path(struct wmOperatorType *ot);
220 void MESH_OT_select_similar(struct wmOperatorType *ot);
221 void MESH_OT_select_random(struct wmOperatorType *ot);
222 void MESH_OT_loop_multi_select(struct wmOperatorType *ot);
223 void MESH_OT_mark_seam(struct wmOperatorType *ot);
224 void MESH_OT_mark_sharp(struct wmOperatorType *ot);
225 void MESH_OT_vertices_smooth(struct wmOperatorType *ot);
226 void MESH_OT_noise(struct wmOperatorType *ot);
227 void EXPORT_MESH_OT_wavefront(struct wmOperatorType *ot);
228 void MESH_OT_flip_normals(struct wmOperatorType *ot);
229 void MESH_OT_solidify(struct wmOperatorType *ot);
230 void MESH_OT_select_nth(struct wmOperatorType *ot);
231 void MESH_OT_select_next_loop(struct wmOperatorType *ot);
232                 
233 #define SUBDIV_SELECT_ORIG      0
234 #define SUBDIV_SELECT_INNER     1
235 #define SUBDIV_SELECT_INNER_SEL 2
236 #define SUBDIV_SELECT_LOOPCUT 3
237
238 /* edge subdivide corner cut types */
239 #define SUBDIV_CORNER_PATH              0
240 #define SUBDIV_CORNER_INNERVERT 1
241 #define SUBDIV_CORNER_FAN               2
242
243 extern EnumPropertyItem corner_type_items[];
244
245 void join_triangles(EditMesh *em);
246 int removedoublesflag(EditMesh *em, short flag, short automerge, float limit);          /* return amount */
247 void esubdivideflag(Object *obedit, EditMesh *em, int flag, float smooth, float fractal, int beautify, int numcuts, int corner_pattern, int seltype);
248 int EdgeSlide(EditMesh *em, struct wmOperator *op, short immediate, float imperc);
249
250 void MESH_OT_merge(struct wmOperatorType *ot);
251 void MESH_OT_subdivide(struct wmOperatorType *ot);
252 void MESH_OT_remove_doubles(struct wmOperatorType *ot);
253 void MESH_OT_vertices_randomize(struct wmOperatorType *ot);
254 void MESH_OT_vertices_sort(struct wmOperatorType *ot);
255 void MESH_OT_extrude(struct wmOperatorType *ot);
256 void MESH_OT_spin(struct wmOperatorType *ot);
257 void MESH_OT_screw(struct wmOperatorType *ot);
258
259 void MESH_OT_fill(struct wmOperatorType *ot);
260 void MESH_OT_beautify_fill(struct wmOperatorType *ot);
261 void MESH_OT_quads_convert_to_tris(struct wmOperatorType *ot);
262 void MESH_OT_tris_convert_to_quads(struct wmOperatorType *ot);
263 void MESH_OT_edge_flip(struct wmOperatorType *ot);
264 void MESH_OT_faces_shade_smooth(struct wmOperatorType *ot);
265 void MESH_OT_faces_shade_flat(struct wmOperatorType *ot);
266 void MESH_OT_split(struct wmOperatorType *ot);
267 void MESH_OT_extrude_repeat(struct wmOperatorType *ot);
268 void MESH_OT_edge_rotate(struct wmOperatorType *ot);
269 void MESH_OT_select_vertex_path(struct wmOperatorType *ot);
270 void MESH_OT_loop_to_region(struct wmOperatorType *ot);
271 void MESH_OT_region_to_loop(struct wmOperatorType *ot);
272 void MESH_OT_select_axis(struct wmOperatorType *ot);
273
274 void MESH_OT_uvs_rotate(struct wmOperatorType *ot);
275 //void MESH_OT_uvs_mirror(struct wmOperatorType *ot);
276 void MESH_OT_uvs_reverse(struct wmOperatorType *ot);
277 void MESH_OT_colors_rotate(struct wmOperatorType *ot);
278 //void MESH_OT_colors_mirror(struct wmOperatorType *ot);
279
280 void MESH_OT_colors_reverse(struct wmOperatorType *ot);
281
282 void MESH_OT_delete(struct wmOperatorType *ot);
283 void MESH_OT_rip(struct wmOperatorType *ot);
284
285 void MESH_OT_shape_propagate_to_all(struct wmOperatorType *ot);
286 void MESH_OT_blend_from_shape(struct wmOperatorType *ot);
287 void MESH_OT_sort_faces(struct wmOperatorType *ot);
288
289 /* ******************* mesh_data.c */
290
291 void MESH_OT_uv_texture_add(struct wmOperatorType *ot);
292 void MESH_OT_uv_texture_remove(struct wmOperatorType *ot);
293 void MESH_OT_vertex_color_add(struct wmOperatorType *ot);
294 void MESH_OT_vertex_color_remove(struct wmOperatorType *ot);
295 void MESH_OT_sticky_add(struct wmOperatorType *ot);
296 void MESH_OT_sticky_remove(struct wmOperatorType *ot);
297 void MESH_OT_drop_named_image(struct wmOperatorType *ot);
298
299 /* ************* bmesh_tools.c ***********/
300 void MESH_OT_vert_connect(struct wmOperatorType *ot);
301 void MESH_OT_edge_split(struct wmOperatorType *ot);
302 void MESH_OT_extrude_region(struct wmOperatorType *ot);
303 void MESH_OT_extrude_verts_indiv(struct wmOperatorType *ot);
304 void MESH_OT_extrude_edges_indiv(struct wmOperatorType *ot);
305 void MESH_OT_extrude_faces_indiv(struct wmOperatorType *ot);
306 void MESH_OT_bm_test(struct wmOperatorType *ot);
307
308 void MESH_OT_edgering_select(struct wmOperatorType *ot);
309 void MESH_OT_loopcut(struct wmOperatorType *ot);
310
311 void MESH_OT_knifetool(struct wmOperatorType *ot);
312 void MESH_OT_bevel(struct wmOperatorType *ot);
313
314 void MESH_OT_bridge_edge_loops(struct wmOperatorType *ot);
315
316 /* ******************* mesh_navmesh.c */
317 void MESH_OT_navmesh_make(struct wmOperatorType *ot);
318 void MESH_OT_navmesh_face_copy(struct wmOperatorType *ot);
319 void MESH_OT_navmesh_face_add(struct wmOperatorType *ot);
320 void MESH_OT_navmesh_reset(struct wmOperatorType *ot);
321 void MESH_OT_navmesh_clear(struct wmOperatorType *ot);
322
323 #endif // MESH_INTERN_H
324