Manual merge of soc-2009-kazanbas branch:
[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., 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 wmOperator;
40 struct wmWindowManager;
41 struct EditSelection;
42 struct ViewContext;
43 struct bDeformGroup;
44 struct MDeformWeight;
45 struct MDeformVert;
46 struct Scene;
47 struct Mesh;
48 struct MCol;
49 struct UvVertMap;
50 struct UvMapVert;
51 struct CustomData;
52
53 #define EM_FGON_DRAW    1 // face flag
54 #define EM_FGON                 2 // edge and face flag both
55
56 /* editbutflag */
57 #define B_CLOCKWISE                     1
58 #define B_KEEPORIG                      2
59 #define B_BEAUTY                        4
60 #define B_SMOOTH                        8
61 #define B_BEAUTY_SHORT          0x10
62 #define B_AUTOFGON                      0x20
63 #define B_KNIFE                         0x80
64 #define B_PERCENTSUBD           0x40
65 #define B_MESH_X_MIRROR         0x100
66 #define B_JOINTRIA_UV           0x200
67 #define B_JOINTRIA_VCOL         0X400
68 #define B_JOINTRIA_SHARP        0X800
69 #define B_JOINTRIA_MAT          0X1000
70 #define B_FRACTAL                       0x2000
71 #define B_SPHERE                        0x4000
72
73 /* meshtools.c */
74
75 intptr_t        mesh_octree_table(struct Object *ob, struct EditMesh *em, float *co, char mode);
76 struct EditVert   *editmesh_get_x_mirror_vert(struct Object *ob, struct EditMesh *em, float *co);
77 int                     mesh_get_x_mirror_vert(struct Object *ob, int index);
78 int                     *mesh_get_x_mirror_faces(struct Object *ob, struct EditMesh *em);
79
80 int                     join_mesh_exec(struct bContext *C, struct wmOperator *op);
81
82 /* mesh_ops.c */
83 void            ED_operatortypes_mesh(void);
84 void            ED_keymap_mesh(struct wmWindowManager *wm);
85
86
87 /* editmesh.c */
88
89 void            ED_spacetypes_init(void);
90 void            ED_keymap_mesh(struct wmWindowManager *wm);
91
92 void            make_editMesh(struct Scene *scene, Object *ob);
93 void            load_editMesh(struct Scene *scene, Object *ob);
94 void            remake_editMesh(struct Scene *scene, Object *ob);
95 void            free_editMesh(struct EditMesh *em);
96
97 void            recalc_editnormals(struct EditMesh *em);
98
99 void            EM_init_index_arrays(struct EditMesh *em, int forVert, int forEdge, int forFace);
100 void            EM_free_index_arrays(void);
101 struct EditVert *EM_get_vert_for_index(int index);
102 struct EditEdge *EM_get_edge_for_index(int index);
103 struct EditFace *EM_get_face_for_index(int index);
104 int                     EM_texFaceCheck(struct EditMesh *em);
105 int                     EM_vertColorCheck(struct EditMesh *em);
106
107 void            undo_push_mesh(struct bContext *C, char *name);
108
109
110 /* editmesh_lib.c */
111
112 struct EditFace *EM_get_actFace(struct EditMesh *em, int sloppy);
113 void             EM_set_actFace(struct EditMesh *em, struct EditFace *efa);
114 float            EM_face_area(struct EditFace *efa);
115
116 void            EM_select_edge(struct EditEdge *eed, int sel);
117 void            EM_select_face(struct EditFace *efa, int sel);
118 void            EM_select_face_fgon(struct EditMesh *em, struct EditFace *efa, int val);
119 void            EM_select_swap(struct EditMesh *em);
120 void            EM_toggle_select_all(struct EditMesh *em);
121 void            EM_select_all(struct EditMesh *em);
122 void            EM_selectmode_flush(struct EditMesh *em);
123 void            EM_deselect_flush(struct EditMesh *em);
124 void            EM_selectmode_set(struct EditMesh *em);
125 void            EM_select_flush(struct EditMesh *em);
126 void            EM_convertsel(struct EditMesh *em, short oldmode, short selectmode);
127 void            EM_validate_selections(struct EditMesh *em);
128
129                         /* exported to transform */
130 int                     EM_get_actSelection(struct EditMesh *em, struct EditSelection *ese);
131 void            EM_editselection_normal(float *normal, struct EditSelection *ese);
132 void            EM_editselection_plane(float *plane, struct EditSelection *ese);
133 void            EM_editselection_center(float *center, struct EditSelection *ese);                      
134
135 struct UvVertMap *EM_make_uv_vert_map(struct EditMesh *em, int selected, int do_face_idx_array, float *limit);
136 struct UvMapVert *EM_get_uv_map_vert(struct UvVertMap *vmap, unsigned int v);
137 void              EM_free_uv_vert_map(struct UvVertMap *vmap);
138
139 void            EM_add_data_layer(struct EditMesh *em, struct CustomData *data, int type);
140 void            EM_free_data_layer(struct EditMesh *em, struct CustomData *data, int type);
141
142 /* editmesh_mods.c */
143 extern unsigned int em_vertoffs, em_solidoffs, em_wireoffs;
144
145 void            mouse_mesh(struct bContext *C, short mval[2], short extend);
146 int                     EM_check_backbuf(unsigned int index);
147 int                     EM_mask_init_backbuf_border(struct ViewContext *vc, short mcords[][2], short tot, short xmin, short ymin, short xmax, short ymax);
148 void            EM_free_backbuf(void);
149 int                     EM_init_backbuf_border(struct ViewContext *vc, short xmin, short ymin, short xmax, short ymax);
150 int                     EM_init_backbuf_circle(struct ViewContext *vc, short xs, short ys, short rads);
151
152 void            EM_hide_mesh(struct EditMesh *em, int swap);
153 void            EM_reveal_mesh(struct EditMesh *em);
154
155 void            EM_select_by_material(struct EditMesh *em, int index);
156 void            EM_deselect_by_material(struct EditMesh *em, int index); 
157
158 /* editface.c */
159 struct MTFace   *EM_get_active_mtface(struct EditMesh *em, struct EditFace **act_efa, struct MCol **mcol, int sloppy);
160
161 /* object_vgroup.c */
162
163 #define WEIGHT_REPLACE 1
164 #define WEIGHT_ADD 2
165 #define WEIGHT_SUBTRACT 3
166
167 struct bDeformGroup             *ED_vgroup_add(struct Object *ob);
168 struct bDeformGroup             *ED_vgroup_add_name(struct Object *ob, char *name);
169 void                                    ED_vgroup_select_by_name(struct Object *ob, char *name);
170 void                                    ED_vgroup_data_create(struct ID *id);
171
172 void            ED_vgroup_vert_add(struct Object *ob, struct bDeformGroup *dg, int vertnum,  float weight, int assignmode);
173 void            ED_vgroup_vert_remove(struct Object *ob, struct bDeformGroup *dg, int vertnum);
174 float           ED_vgroup_vert_weight(struct Object *ob, struct bDeformGroup *dg, int vertnum);
175
176 struct MDeformWeight    *ED_vgroup_weight_verify(struct MDeformVert *dv, int defgroup);
177 struct MDeformWeight    *ED_vgroup_weight_get(struct MDeformVert *dv, int defgroup);
178
179 /*needed by edge slide*/
180 struct EditVert *editedge_getOtherVert(struct EditEdge *eed, struct EditVert *eve);
181 struct EditVert *editedge_getSharedVert(struct EditEdge *eed, struct EditEdge *eed2);
182 int editedge_containsVert(struct EditEdge *eed, struct EditVert *eve);
183 int editface_containsVert(struct EditFace *efa, struct EditVert *eve);
184 int editface_containsEdge(struct EditFace *efa, struct EditEdge *eed);
185 short sharesFace(struct EditMesh *em, struct EditEdge *e1, struct EditEdge *e2);
186
187 #endif /* ED_MESH_H */
188