dd29f2706809d5b4b6bf253aa7d37067993c42ff
[blender-staging.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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, 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 struct ID;
32 struct View3D;
33 struct ARegion;
34 struct EditMesh;
35 struct EditVert;
36 struct EditEdge;
37 struct EditFace;
38 struct bContext;
39 struct wmWindowManager;
40 struct EditSelection;
41 struct ViewContext;
42 struct bDeformGroup;
43 struct MDeformWeight;
44 struct MDeformVert;
45 struct Scene;
46 struct Mesh;
47 struct MCol;
48 struct UvVertMap;
49 struct UvMapVert;
50 struct CustomData;
51 struct BMEditSelection;
52 struct BMesh;
53 struct BMVert;
54 struct BMEdge;
55 struct BMFace;
56
57 // edge and face flag both
58 #define EM_FGON         2
59 // face flag
60 #define EM_FGON_DRAW    1
61
62 /* editbutflag */
63 #define B_CLOCKWISE             1
64 #define B_KEEPORIG              2
65 #define B_BEAUTY                4
66 #define B_SMOOTH                8
67 #define B_BEAUTY_SHORT          16
68 #define B_AUTOFGON              32
69 #define B_KNIFE                 0x80
70 #define B_PERCENTSUBD           0x40
71 #define B_MESH_X_MIRROR         0x100
72 #define B_JOINTRIA_UV           0x200
73 #define B_JOINTRIA_VCOL         0X400
74 #define B_JOINTRIA_SHARP        0X800
75 #define B_JOINTRIA_MAT          0X1000
76 #define B_FRACTAL               0x2000
77 #define B_SPHERE                0x4000
78
79 /* bmeshutils.c */
80
81 /*this function is currently defunct, dead*/
82 void EDBM_Tesselate(struct EditMesh *em);
83 void EDBM_RecalcNormals(struct BMEditMesh *em);
84 void EDBM_MakeEditBMesh(struct Scene *scene, struct Object *ob);
85 void EDBM_FreeEditBMesh(struct BMEditMesh *tm);
86 void EDBM_LoadEditBMesh(struct Scene *scene, struct Object *ob);
87 void EDBM_init_index_arrays(struct BMEditMesh *tm, int forvert, int foredge, int forface);
88 void EDBM_free_index_arrays(struct BMEditMesh *tm);
89 struct BMVert *EDBM_get_vert_for_index(struct BMEditMesh *tm, int index);
90 struct BMEdge *EDBM_get_edge_for_index(struct BMEditMesh *tm, int index);
91 struct BMFace *EDBM_get_face_for_index(struct BMEditMesh *tm, int index);
92 struct BMFace *EDBM_get_actFace(struct BMEditMesh *em, int sloppy);
93 void EDBM_selectmode_flush(struct BMEditMesh *em);
94 int EDBM_get_actSelection(struct BMEditMesh *em, struct BMEditSelection *ese);
95 void EDBM_editselection_center(struct BMEditMesh *em, float *center, struct BMEditSelection *ese);
96 void EDBM_editselection_plane(struct BMEditMesh *em, float *plane, struct BMEditSelection *ese);
97 void EDBM_editselection_normal(float *normal, struct BMEditSelection *ese);
98 void EDBM_selectmode_set(struct BMEditMesh *em);
99 void EDBM_convertsel(struct BMEditMesh *em, short oldmode, short selectmode);
100
101 int                     EDBM_check_backbuf(unsigned int index);
102 int                     EDBM_mask_init_backbuf_border(struct ViewContext *vc, short mcords[][2], short tot, short xmin, short ymin, short xmax, short ymax);
103 void            EDBM_free_backbuf(void);
104 int                     EDBM_init_backbuf_border(struct ViewContext *vc, short xmin, short ymin, short xmax, short ymax);
105 int                     EDBM_init_backbuf_circle(struct ViewContext *vc, short xs, short ys, short rads);
106
107 /* meshtools.c */
108
109 intptr_t        mesh_octree_table(struct Object *ob, struct BMEditMesh *em, float *co, char mode);
110 struct BMVert   *editmesh_get_x_mirror_vert(struct Object *ob, struct BMEditMesh *em, float *co);
111 int                     mesh_get_x_mirror_vert(struct Object *ob, int index);
112 int                     *mesh_get_x_mirror_faces(struct Object *ob, struct BMEditMesh *em);
113
114 /* mesh_ops.c */
115 void            ED_operatortypes_mesh(void);
116 void            ED_keymap_mesh(struct wmWindowManager *wm);
117
118
119 /* editmesh.c */
120
121 void            ED_spacetypes_init(void);
122 void            ED_keymap_mesh(struct wmWindowManager *wm);
123
124 struct EditMesh *make_editMesh(struct Scene *scene, Object *ob);
125 void            load_editMesh(struct Scene *scene, Object *ob, struct EditMesh *em);
126 void            remake_editMesh(struct Scene *scene, Object *ob);
127 void            free_editMesh(struct EditMesh *em);
128
129 void            recalc_editnormals(struct EditMesh *em);
130
131 void            EM_init_index_arrays(struct EditMesh *em, int forVert, int forEdge, int forFace);
132 void            EM_free_index_arrays(void);
133 struct EditVert *EM_get_vert_for_index(int index);
134 struct EditEdge *EM_get_edge_for_index(int index);
135 struct EditFace *EM_get_face_for_index(int index);
136 int                     EM_texFaceCheck(struct EditMesh *em);
137 int                     EM_vertColorCheck(struct EditMesh *em);
138
139 void            undo_push_mesh(struct bContext *C, char *name);
140
141
142 /* editmesh_lib.c */
143
144 struct EditFace *EM_get_actFace(struct EditMesh *em, int sloppy);
145 void             EM_set_actFace(struct EditMesh *em, struct EditFace *efa);
146 float            EM_face_area(struct EditFace *efa);
147 void             EM_add_data_layer(struct EditMesh *em, struct CustomData *data, int type);
148
149 void            EM_select_edge(struct EditEdge *eed, int sel);
150 void            EM_select_face(struct EditFace *efa, int sel);
151 void            EM_select_face_fgon(struct EditMesh *em, struct EditFace *efa, int val);
152 void            EM_select_swap(struct EditMesh *em);
153 void            EM_toggle_select_all(struct EditMesh *em);
154 void            EM_selectmode_flush(struct EditMesh *em);
155 void            EM_deselect_flush(struct EditMesh *em);
156 void            EM_selectmode_set(struct EditMesh *em);
157 void            EM_select_flush(struct EditMesh *em);
158 void            EM_convertsel(struct EditMesh *em, short oldmode, short selectmode);
159 void            EM_validate_selections(struct EditMesh *em);
160
161                         /* exported to transform */
162 int                     EM_get_actSelection(struct EditMesh *em, struct EditSelection *ese);
163 void            EM_editselection_normal(float *normal, struct EditSelection *ese);
164 void            EM_editselection_plane(float *plane, struct EditSelection *ese);
165 void            EM_editselection_center(float *center, struct EditSelection *ese);                      
166
167 struct UvVertMap *EM_make_uv_vert_map(struct EditMesh *em, int selected, int do_face_idx_array, float *limit);
168 struct UvMapVert *EM_get_uv_map_vert(struct UvVertMap *vmap, unsigned int v);
169 void              EM_free_uv_vert_map(struct UvVertMap *vmap);
170
171 /* editmesh_mods.c */
172 extern unsigned int bm_vertoffs, bm_solidoffs, bm_wireoffs;
173
174 void            mouse_mesh(struct bContext *C, short mval[2], short extend);
175 int                     EM_check_backbuf(unsigned int index);
176 int                     EM_mask_init_backbuf_border(struct ViewContext *vc, short mcords[][2], short tot, short xmin, short ymin, short xmax, short ymax);
177 void            EM_free_backbuf(void);
178 int                     EM_init_backbuf_border(struct ViewContext *vc, short xmin, short ymin, short xmax, short ymax);
179 int                     EM_init_backbuf_circle(struct ViewContext *vc, short xs, short ys, short rads);
180
181 void            EM_hide_mesh(struct EditMesh *em, int swap);
182 void            EM_reveal_mesh(struct EditMesh *em);
183
184 /* editface.c */
185 struct MTFace   *EM_get_active_mtface(struct EditMesh *em, struct EditFace **act_efa, struct MCol **mcol, int sloppy);
186
187 /* editdeform.c XXX rename functions? */
188
189 #define WEIGHT_REPLACE 1
190 #define WEIGHT_ADD 2
191 #define WEIGHT_SUBTRACT 3
192
193 void            add_defgroup (Object *ob);
194 void            create_dverts(struct ID *id);
195 float           get_vert_defgroup (Object *ob, struct bDeformGroup *dg, int vertnum);
196 void            remove_vert_defgroup (Object *ob, struct bDeformGroup *dg, int vertnum);
197 void            remove_verts_defgroup (Object *obedit, int allverts);
198 void            vertexgroup_select_by_name(Object *ob, char *name);
199 void            add_vert_to_defgroup (Object *ob, struct bDeformGroup *dg, int vertnum, 
200                            float weight, int assignmode);
201
202 struct bDeformGroup             *add_defgroup_name (Object *ob, char *name);
203 struct MDeformWeight    *verify_defweight (struct MDeformVert *dv, int defgroup);
204 struct MDeformWeight    *get_defweight (struct MDeformVert *dv, int defgroup);
205
206
207 #endif /* ED_MESH_H */
208