0dde2b2f695fc082f703229b92fb920b2cfcde2e
[blender.git] / source / blender / include / editmesh.h
1 /**
2  * $Id: 
3  *
4  * ***** BEGIN GPL/BL DUAL 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. The Blender
10  * Foundation also sells licenses for use in proprietary software under
11  * the Blender License.  See http://www.blender.org/BL/ for information
12  * about this.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software Foundation,
21  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22  *
23  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
24  * All rights reserved.
25  *
26  * The Original Code is: all of this file.
27  *
28  * Contributor(s): none yet.
29  *
30  * ***** END GPL/BL DUAL LICENSE BLOCK *****
31  */
32
33 /* Internal for editmesh_xxxx.c functions */
34
35 #ifndef EDITMESH_H
36 #define EDITMESH_H
37
38 #define TEST_EDITMESH   if(G.obedit==0) return; \
39                                                 if( (G.vd->lay & G.obedit->lay)==0 ) return;
40
41 #define UVCOPY(t, s) memcpy(t, s, 2 * sizeof(float));
42
43
44
45 /* ******************* editmesh.c */
46 extern void free_editvert(EditVert *eve);
47 extern void free_editedge(EditEdge *eed);
48 extern void free_editface(EditFace *efa);
49
50 extern void free_vertlist(ListBase *edve);
51 extern void free_edgelist(ListBase *lb);
52 extern void free_facelist(ListBase *lb);
53
54 extern void remedge(EditEdge *eed);
55
56 extern struct EditVert *addvertlist(float *vec, struct EditVert *example);
57 extern struct EditEdge *addedgelist(struct EditVert *v1, struct EditVert *v2, struct EditEdge *example);
58 extern struct EditFace *addfacelist(struct EditVert *v1, struct EditVert *v2, struct EditVert *v3, struct EditVert *v4, struct EditFace *example, struct EditFace *exampleEdges);
59 extern struct EditEdge *findedgelist(struct EditVert *v1, struct EditVert *v2);
60
61 /* ******************* editmesh_add.c */
62
63
64 /* ******************* editmesh_lib.c */
65 extern void EM_fgon_flags(void);
66 extern void EM_hide_reset(void);
67
68 extern int faceselectedOR(EditFace *efa, int flag);
69 extern int faceselectedAND(EditFace *efa, int flag);
70
71 extern EditFace *exist_face(EditVert *v1, EditVert *v2, EditVert *v3, EditVert *v4);
72 extern void flipface(EditFace *efa); // flips for normal direction
73 extern int compareface(EditFace *vl1, EditFace *vl2);
74
75 /* flag for selection bits, *nor will be filled with normal for extrusion constraint */
76 /* return value defines if such normal was set */
77 extern short extrudeflag_face_indiv(short flag, float *nor);
78 extern short extrudeflag_verts_indiv(short flag, float *nor);
79 extern short extrudeflag_edges_indiv(short flag, float *nor);
80 extern short extrudeflag_vert(short flag, float *nor);
81 extern short extrudeflag(short flag, float *nor);
82
83 extern void adduplicateflag(int flag);
84 extern void delfaceflag(int flag);
85
86 extern void rotateflag(short flag, float *cent, float rotmat[][3]);
87 extern void translateflag(short flag, float *vec);
88
89 extern int convex(float *v1, float *v2, float *v3, float *v4);
90
91 /* ******************* editmesh_mods.c */
92 extern EditEdge *findnearestedge(int *dist);
93
94 /**
95  * findnearestvert
96  * 
97  * dist (in/out): minimal distance to the nearest and at the end, actual distance
98  * sel: selection bias
99  *              if SELECT, selected vertice are given a 5 pixel bias to make them farter than unselect verts
100  *              if 0, unselected vertice are given the bias
101  * strict: if 1, the vertice corresponding to the sel parameter are ignored and not just biased 
102  */
103 extern EditVert *findnearestvert(int *dist, short sel, short strict);
104
105 /* ******************* editmesh_tools.c */
106
107 /* multires.c */
108 int multires_test();
109
110 #endif
111