Merge with -r 22620:23107.
[blender.git] / source / blender / editors / include / ED_mesh.h
index 6dff4ee..1045da5 100644 (file)
@@ -36,6 +36,7 @@ struct EditVert;
 struct EditEdge;
 struct EditFace;
 struct bContext;
+struct wmOperator;
 struct wmWindowManager;
 struct EditSelection;
 struct ViewContext;
@@ -49,26 +50,25 @@ struct UvVertMap;
 struct UvMapVert;
 struct CustomData;
 
-// edge and face flag both
-#define EM_FGON                2
-// face flag
-#define EM_FGON_DRAW   1
+#define EM_FGON_DRAW   1 // face flag
+#define EM_FGON                        2 // edge and face flag both
 
 /* editbutflag */
-#define B_CLOCKWISE            1
-#define B_KEEPORIG             2
-#define B_BEAUTY               4
-#define B_SMOOTH               8
-#define B_BEAUTY_SHORT         16
-#define B_AUTOFGON             32
-#define B_KNIFE                        0x80
+#define B_CLOCKWISE                    1
+#define B_KEEPORIG                     2
+#define B_BEAUTY                       4
+#define B_SMOOTH                       8
+#define B_BEAUTY_SHORT         0x10
+#define B_AUTOFGON                     0x20
+#define B_KNIFE                                0x80
 #define B_PERCENTSUBD          0x40
 #define B_MESH_X_MIRROR                0x100
 #define B_JOINTRIA_UV          0x200
 #define B_JOINTRIA_VCOL                0X400
 #define B_JOINTRIA_SHARP       0X800
 #define B_JOINTRIA_MAT         0X1000
-
+#define B_FRACTAL                      0x2000
+#define B_SPHERE                       0x4000
 
 /* meshtools.c */
 
@@ -77,6 +77,8 @@ struct EditVert   *editmesh_get_x_mirror_vert(struct Object *ob, struct EditMesh
 int                    mesh_get_x_mirror_vert(struct Object *ob, int index);
 int                    *mesh_get_x_mirror_faces(struct Object *ob, struct EditMesh *em);
 
+int                    join_mesh_exec(struct bContext *C, struct wmOperator *op);
+
 /* mesh_ops.c */
 void           ED_operatortypes_mesh(void);
 void           ED_keymap_mesh(struct wmWindowManager *wm);
@@ -110,13 +112,13 @@ void              undo_push_mesh(struct bContext *C, char *name);
 struct EditFace        *EM_get_actFace(struct EditMesh *em, int sloppy);
 void             EM_set_actFace(struct EditMesh *em, struct EditFace *efa);
 float            EM_face_area(struct EditFace *efa);
-void             EM_add_data_layer(struct EditMesh *em, struct CustomData *data, int type);
 
 void           EM_select_edge(struct EditEdge *eed, int sel);
 void           EM_select_face(struct EditFace *efa, int sel);
 void           EM_select_face_fgon(struct EditMesh *em, struct EditFace *efa, int val);
 void           EM_select_swap(struct EditMesh *em);
 void           EM_toggle_select_all(struct EditMesh *em);
+void EM_select_all(struct EditMesh *em);
 void           EM_selectmode_flush(struct EditMesh *em);
 void           EM_deselect_flush(struct EditMesh *em);
 void           EM_selectmode_set(struct EditMesh *em);
@@ -134,6 +136,9 @@ struct UvVertMap *EM_make_uv_vert_map(struct EditMesh *em, int selected, int do_
 struct UvMapVert *EM_get_uv_map_vert(struct UvVertMap *vmap, unsigned int v);
 void              EM_free_uv_vert_map(struct UvVertMap *vmap);
 
+void           EM_add_data_layer(struct EditMesh *em, struct CustomData *data, int type);
+void           EM_free_data_layer(struct EditMesh *em, struct CustomData *data, int type);
+
 /* editmesh_mods.c */
 extern unsigned int em_vertoffs, em_solidoffs, em_wireoffs;
 
@@ -147,28 +152,32 @@ int                       EM_init_backbuf_circle(struct ViewContext *vc, short xs, short ys, short r
 void           EM_hide_mesh(struct EditMesh *em, int swap);
 void           EM_reveal_mesh(struct EditMesh *em);
 
+void           EM_select_by_material(struct EditMesh *em, int index);
+void           EM_deselect_by_material(struct EditMesh *em, int index); 
+
+/* editmesh_tools.c */
+void convert_to_triface(struct EditMesh *em, int direction);
+
 /* editface.c */
 struct MTFace  *EM_get_active_mtface(struct EditMesh *em, struct EditFace **act_efa, struct MCol **mcol, int sloppy);
 
-/* editdeform.c XXX rename functions? */
+/* object_vgroup.c */
 
 #define WEIGHT_REPLACE 1
 #define WEIGHT_ADD 2
 #define WEIGHT_SUBTRACT 3
 
-void           add_defgroup (Object *ob);
-void           create_dverts(struct ID *id);
-float          get_vert_defgroup (Object *ob, struct bDeformGroup *dg, int vertnum);
-void           remove_vert_defgroup (Object *ob, struct bDeformGroup *dg, int vertnum);
-void           remove_verts_defgroup (Object *obedit, int allverts);
-void           vertexgroup_select_by_name(Object *ob, char *name);
-void           add_vert_to_defgroup (Object *ob, struct bDeformGroup *dg, int vertnum, 
-                           float weight, int assignmode);
+struct bDeformGroup            *ED_vgroup_add(struct Object *ob);
+struct bDeformGroup            *ED_vgroup_add_name(struct Object *ob, char *name);
+void                                   ED_vgroup_select_by_name(struct Object *ob, char *name);
+void                                   ED_vgroup_data_create(struct ID *id);
 
-struct bDeformGroup            *add_defgroup_name (Object *ob, char *name);
-struct MDeformWeight   *verify_defweight (struct MDeformVert *dv, int defgroup);
-struct MDeformWeight   *get_defweight (struct MDeformVert *dv, int defgroup);
+void           ED_vgroup_vert_add(struct Object *ob, struct bDeformGroup *dg, int vertnum,  float weight, int assignmode);
+void           ED_vgroup_vert_remove(struct Object *ob, struct bDeformGroup *dg, int vertnum);
+float          ED_vgroup_vert_weight(struct Object *ob, struct bDeformGroup *dg, int vertnum);
 
+struct MDeformWeight   *ED_vgroup_weight_verify(struct MDeformVert *dv, int defgroup);
+struct MDeformWeight   *ED_vgroup_weight_get(struct MDeformVert *dv, int defgroup);
 
 #endif /* ED_MESH_H */