22779fbba0b9a83fedd93f97c84fde6b987a16e3
[blender.git] / source / blender / editors / include / ED_mesh.h
1 /**
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. 
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19  *
20  * The Original Code is Copyright (C) 2008 Blender Foundation.
21  * All rights reserved.
22  *
23  * 
24  * Contributor(s): Blender Foundation
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28 #ifndef ED_MESH_H
29 #define ED_MESH_H
30
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
34
35 struct ID;
36 struct View3D;
37 struct ARegion;
38 struct EditMesh;
39 struct EditVert;
40 struct EditEdge;
41 struct EditFace;
42 struct bContext;
43 struct wmOperator;
44 struct wmWindowManager;
45 struct wmKeyConfig;
46 struct ReportList;
47 struct EditSelection;
48 struct ViewContext;
49 struct bDeformGroup;
50 struct MDeformWeight;
51 struct MDeformVert;
52 struct Scene;
53 struct Mesh;
54 struct MCol;
55 struct UvVertMap;
56 struct UvMapVert;
57 struct CustomData;
58 struct Material;
59 struct Object;
60 struct rcti;
61
62 #define EM_FGON_DRAW    1 // face flag
63 #define EM_FGON                 2 // edge and face flag both
64
65 /* editbutflag */
66 #define B_CLOCKWISE                     1
67 #define B_KEEPORIG                      2
68 #define B_BEAUTY                        4
69 #define B_SMOOTH                        8
70 #define B_BEAUTY_SHORT          0x10
71 #define B_AUTOFGON                      0x20
72 #define B_KNIFE                         0x80
73 #define B_PERCENTSUBD           0x40
74 //#define B_MESH_X_MIRROR               0x100 // deprecated, use mesh
75 #define B_JOINTRIA_UV           0x200
76 #define B_JOINTRIA_VCOL         0X400
77 #define B_JOINTRIA_SHARP        0X800
78 #define B_JOINTRIA_MAT          0X1000
79 #define B_FRACTAL                       0x2000
80 #define B_SPHERE                        0x4000
81
82 /* meshtools.c */
83
84 intptr_t        mesh_octree_table(struct Object *ob, struct EditMesh *em, float *co, char mode);
85 long            mesh_mirrtopo_table(struct Object *ob, char mode);
86
87 struct EditVert   *editmesh_get_x_mirror_vert(struct Object *ob, struct EditMesh *em, struct EditVert *eve, float *co, int index);
88 int                     mesh_get_x_mirror_vert(struct Object *ob, int index);
89 int                     *mesh_get_x_mirror_faces(struct Object *ob, struct EditMesh *em);
90
91 int                     join_mesh_exec(struct bContext *C, struct wmOperator *op);
92 int                     join_mesh_shapes_exec(struct bContext *C, struct wmOperator *op);
93
94 /* mesh_ops.c */
95 void            ED_operatortypes_mesh(void);
96 void            ED_operatormacros_mesh(void);
97 void            ED_keymap_mesh(struct wmKeyConfig *keyconf);
98
99
100 /* editmesh.c */
101
102 void            ED_spacetypes_init(void);
103 void            ED_keymap_mesh(struct wmKeyConfig *keyconf);
104
105 void            make_editMesh(struct Scene *scene, struct Object *ob);
106 void            load_editMesh(struct Scene *scene, struct Object *ob);
107 void            remake_editMesh(struct Scene *scene, struct Object *ob);
108 void            free_editMesh(struct EditMesh *em);
109
110 void            recalc_editnormals(struct EditMesh *em);
111
112 void            EM_init_index_arrays(struct EditMesh *em, int forVert, int forEdge, int forFace);
113 void            EM_free_index_arrays(void);
114 struct EditVert *EM_get_vert_for_index(int index);
115 struct EditEdge *EM_get_edge_for_index(int index);
116 struct EditFace *EM_get_face_for_index(int index);
117 int                     EM_texFaceCheck(struct EditMesh *em);
118 int                     EM_vertColorCheck(struct EditMesh *em);
119
120 void            undo_push_mesh(struct bContext *C, char *name);
121
122
123 /* editmesh_lib.c */
124
125 struct EditFace *EM_get_actFace(struct EditMesh *em, int sloppy);
126 void             EM_set_actFace(struct EditMesh *em, struct EditFace *efa);
127 float            EM_face_area(struct EditFace *efa);
128
129 void            EM_select_edge(struct EditEdge *eed, int sel);
130 void            EM_select_face(struct EditFace *efa, int sel);
131 void            EM_select_face_fgon(struct EditMesh *em, struct EditFace *efa, int val);
132 void            EM_select_swap(struct EditMesh *em);
133 void            EM_toggle_select_all(struct EditMesh *em);
134 void            EM_select_all(struct EditMesh *em);
135 void            EM_deselect_all(struct EditMesh *em);
136 void            EM_selectmode_flush(struct EditMesh *em);
137 void            EM_deselect_flush(struct EditMesh *em);
138 void            EM_selectmode_set(struct EditMesh *em);
139 void            EM_select_flush(struct EditMesh *em);
140 void            EM_convertsel(struct EditMesh *em, short oldmode, short selectmode);
141 void            EM_validate_selections(struct EditMesh *em);
142 void            EM_selectmode_to_scene(struct Scene *scene, struct Object *obedit);
143
144                         /* exported to transform */
145 int                     EM_get_actSelection(struct EditMesh *em, struct EditSelection *ese);
146 void            EM_editselection_normal(float *normal, struct EditSelection *ese);
147 void            EM_editselection_plane(float *plane, struct EditSelection *ese);
148 void            EM_editselection_center(float *center, struct EditSelection *ese);                      
149
150 struct UvVertMap *EM_make_uv_vert_map(struct EditMesh *em, int selected, int do_face_idx_array, float *limit);
151 struct UvMapVert *EM_get_uv_map_vert(struct UvVertMap *vmap, unsigned int v);
152 void              EM_free_uv_vert_map(struct UvVertMap *vmap);
153
154 void            EM_add_data_layer(struct EditMesh *em, struct CustomData *data, int type, const char *name);
155 void            EM_free_data_layer(struct EditMesh *em, struct CustomData *data, int type);
156
157 void            EM_make_hq_normals(struct EditMesh *em);
158 void            EM_solidify(struct EditMesh *em, float dist);
159
160 int                     EM_deselect_nth(struct EditMesh *em, int nth);
161
162 void EM_project_snap_verts(struct bContext *C, struct ARegion *ar, struct Object *obedit, struct EditMesh *em);
163
164 /* editmesh_mods.c */
165 extern unsigned int em_vertoffs, em_solidoffs, em_wireoffs;
166
167 void            EM_cache_x_mirror_vert(struct Object *ob, struct EditMesh *em);
168 int                     mouse_mesh(struct bContext *C, short mval[2], short extend);
169 int                     EM_check_backbuf(unsigned int index);
170 int                     EM_mask_init_backbuf_border(struct ViewContext *vc, short mcords[][2], short tot, short xmin, short ymin, short xmax, short ymax);
171 void            EM_free_backbuf(void);
172 int                     EM_init_backbuf_border(struct ViewContext *vc, short xmin, short ymin, short xmax, short ymax);
173 int                     EM_init_backbuf_circle(struct ViewContext *vc, short xs, short ys, short rads);
174
175 void            EM_hide_mesh(struct EditMesh *em, int swap);
176 void            EM_reveal_mesh(struct EditMesh *em);
177
178 void            EM_select_by_material(struct EditMesh *em, int index);
179 void            EM_deselect_by_material(struct EditMesh *em, int index); 
180
181 void            EM_automerge(struct Scene *scene, struct Object *obedit, int update);
182
183 /* editface.c */
184 struct MTFace   *EM_get_active_mtface(struct EditMesh *em, struct EditFace **act_efa, struct MCol **mcol, int sloppy);
185 int face_select(struct bContext *C, struct Object *ob, short mval[2], int extend);
186 void face_borderselect(struct bContext *C, struct Object *ob, struct rcti *rect, int select, int extend);
187 void selectall_tface(struct Object *ob, int action);
188 void select_linked_tfaces(struct bContext *C, struct Object *ob, short mval[2], int mode);
189 int minmax_tface(struct Object *ob, float *min, float *max);
190
191 /* object_vgroup.c */
192
193 #define WEIGHT_REPLACE 1
194 #define WEIGHT_ADD 2
195 #define WEIGHT_SUBTRACT 3
196
197 struct bDeformGroup             *ED_vgroup_add(struct Object *ob);
198 struct bDeformGroup             *ED_vgroup_add_name(struct Object *ob, char *name);
199 void                                    ED_vgroup_select_by_name(struct Object *ob, char *name);
200 void                                    ED_vgroup_data_create(struct ID *id);
201 int                                             ED_vgroup_give_array(struct ID *id, struct MDeformVert **dvert_arr, int *dvert_tot);
202 int                                             ED_vgroup_copy_array(struct Object *ob, struct Object *ob_from);
203 void                                    ED_vgroup_mirror(struct Object *ob, int mirror_weights, int flip_vgroups);
204
205 void            ED_vgroup_vert_add(struct Object *ob, struct bDeformGroup *dg, int vertnum,  float weight, int assignmode);
206 void            ED_vgroup_vert_remove(struct Object *ob, struct bDeformGroup *dg, int vertnum);
207 float           ED_vgroup_vert_weight(struct Object *ob, struct bDeformGroup *dg, int vertnum);
208
209 /*needed by edge slide*/
210 struct EditVert *editedge_getOtherVert(struct EditEdge *eed, struct EditVert *eve);
211 struct EditVert *editedge_getSharedVert(struct EditEdge *eed, struct EditEdge *eed2);
212 int editedge_containsVert(struct EditEdge *eed, struct EditVert *eve);
213 int editface_containsVert(struct EditFace *efa, struct EditVert *eve);
214 int editface_containsEdge(struct EditFace *efa, struct EditEdge *eed);
215 short sharesFace(struct EditMesh *em, struct EditEdge *e1, struct EditEdge *e2);
216
217 /* mesh_data.c */
218 // void ED_mesh_geometry_add(struct Mesh *mesh, struct ReportList *reports, int verts, int edges, int faces);
219 void ED_mesh_faces_add(struct Mesh *mesh, struct ReportList *reports, int count);
220 void ED_mesh_edges_add(struct Mesh *mesh, struct ReportList *reports, int count);
221 void ED_mesh_vertices_add(struct Mesh *mesh, struct ReportList *reports, int count);
222
223 void ED_mesh_transform(struct Mesh *me, float *mat);
224 void ED_mesh_calc_normals(struct Mesh *me);
225 void ED_mesh_material_link(struct Mesh *me, struct Material *ma);
226 void ED_mesh_update(struct Mesh *mesh, struct bContext *C, int calc_edges);
227
228 int ED_mesh_uv_texture_add(struct bContext *C, struct Mesh *me, const char *name, int active_set);
229 int ED_mesh_uv_texture_remove(struct bContext *C, struct Object *ob, struct Mesh *me);
230 int ED_mesh_color_add(struct bContext *C, struct Scene *scene, struct Object *ob, struct Mesh *me, const char *name, int active_set);
231 int ED_mesh_color_remove(struct bContext *C, struct Object *ob, struct Mesh *me);
232
233 #ifdef __cplusplus
234 }
235 #endif
236
237 #endif /* ED_MESH_H */
238