| 
									
										
										
										
											2011-02-18 13:05:18 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2008-04-16 22:40:48 +00:00
										 |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							| 
									
										
										
										
											2008-04-16 22:40:48 +00:00
										 |  |  |  * of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-10-10 09:38:02 +00:00
										 |  |  |  * Contributor(s): (mar-2001 nzc) | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-16 22:40:48 +00:00
										 |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #ifndef __BKE_MESH_H__
 | 
					
						
							|  |  |  | #define __BKE_MESH_H__
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-18 13:05:18 +00:00
										 |  |  | /** \file BKE_mesh.h
 | 
					
						
							|  |  |  |  *  \ingroup bke | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | /***/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-14 18:04:27 +00:00
										 |  |  | struct BoundBox; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | struct DispList; | 
					
						
							|  |  |  | struct ListBase; | 
					
						
							| 
									
										
										
										
											2010-09-04 05:31:25 +00:00
										 |  |  | struct BMEditMesh; | 
					
						
							|  |  |  | struct BMesh; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | struct Mesh; | 
					
						
							| 
									
										
										
										
											2010-09-04 05:31:25 +00:00
										 |  |  | struct MPoly; | 
					
						
							|  |  |  | struct MLoop; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | struct MFace; | 
					
						
							| 
									
										
										
										
											2009-01-23 20:36:47 +00:00
										 |  |  | struct MEdge; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | struct MVert; | 
					
						
							| 
									
										
										
										
											2010-09-04 05:31:25 +00:00
										 |  |  | struct MDeformVert; | 
					
						
							| 
									
										
											  
											
												 - convert all DerivedMesh map functions to use index based
   mapping (instead of Edit{Vert,Edge,Face} pointers)
 - dropped convertToDispListMeshMapped (whew, glad of it too)
 - added DerivedMesh drawMappedFaces function
 - dropped EM suffix for DerivedMesh functions, it was neither
   particularly correct nor descriptive
 - converted test_index_mface to test_index_face that also corrects
   MCol and TFace. Good thing we had three versions of this routine,
   you never know when one might burn down.
 - removed flipnorm_mesh, not used anymore (and was incorrect to
   boot)
 - Getting face select to work with modifiers turned out to be much
   more complicated than expected. Reworked mapping architecture for
   modifiers - basically elements in a DispListMesh are now required
   to be stored in an order that corresponds exactly to original
   ordering. MVert/MEdge/MFace all have a new flag ME_XXX_STEPINDEX
   that is set on each element that is set on the first derived element
   of each original element. I can't say the code to follow these
   requirements for subsurf is particularly transparent, but on the
   upside it is a reasonably consistent and simple system that is memory
   efficient and allows keeping the DispListMesh structure.
 - rewrote mirror modifier to be simpler/conform to new requirements
   for mapped DispListMesh structure. This also means that mirror interacts
   much better with incremental subsurf calculation (it used to recalc
   one entire side on any topology change, now it generally avoids that).
 - added EM_{init,free}_index_arrays and EM_get_{vert,edge,face}_for_index
   functions to handle mapping indices back into appropriate EditMesh
   structures.
 - bug fix, make edges didn't recalc object data
 - bug fix, initial image assignment to TFace's didn't recalc object data
 - new feature, added circle select support for FACESELECT
 - bug fix, creating new faces in editmode duplicated the TFACE active
   flag - but there should only be one active tface
 - bug fix, possible crash when deleting all faces in faceselect mode
   on mesh with tfaces...
Still todo: TFace edge drawing is still not always correct in face
mode, in particular with a mirror modifier when mesh has edges (and
no preceeding subsurf). Have not yet decided how to deal with this.
Best solution is probably to do switch to meshes all having MEdge's,
in which case I can get rid of TFace edge flags (and need to recalc
modifiers on tface selection change).
											
										 
											2005-08-20 03:08:23 +00:00
										 |  |  | struct MCol; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | struct Object; | 
					
						
							| 
									
										
											  
											
												
Added custom vertex/edge/face data for meshes:
All data layers, including MVert/MEdge/MFace, are now managed as custom
data layers. The pointers like Mesh.mvert, Mesh.dvert or Mesh.mcol are
still used of course, but allocating, copying or freeing these arrays
should be done through the CustomData API.
Work in progress documentation on this is here:
http://mediawiki.blender.org/index.php/BlenderDev/BlenderArchitecture/CustomData
Replaced TFace by MTFace:
This is the same struct, except that it does not contain color, that now
always stays separated in MCol. This was not a good design decision to
begin with, and it is needed for adding multiple color layers later. Note
that this does mean older Blender versions will not be able to read UV
coordinates from the next release, due to an SDNA limitation.
Removed DispListMesh:
This now fully replaced by DerivedMesh. To provide access to arrays of
vertices, edges and faces, like DispListMesh does. The semantics of the
DerivedMesh.getVertArray() and similar functions were changed to return
a pointer to an array if one exists, or otherwise allocate a temporary
one. On releasing the DerivedMesh, this temporary array will be removed
automatically.
Removed ssDM and meshDM DerivedMesh backends:
The ssDM backend was for DispListMesh, so that became obsolete automatically.
The meshDM backend was replaced by the custom data backend, that now figures
out which layers need to be modified, and only duplicates those.
This changes code in many places, and overall removes 2514 lines of code.
So, there's a good chance this might break some stuff, although I've been
testing it for a few days now. The good news is, adding multiple color and
uv layers should now become easy.
											
										 
											2006-11-20 04:28:02 +00:00
										 |  |  | struct MTFace; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | struct VecNor; | 
					
						
							| 
									
										
											  
											
												
Added custom vertex/edge/face data for meshes:
All data layers, including MVert/MEdge/MFace, are now managed as custom
data layers. The pointers like Mesh.mvert, Mesh.dvert or Mesh.mcol are
still used of course, but allocating, copying or freeing these arrays
should be done through the CustomData API.
Work in progress documentation on this is here:
http://mediawiki.blender.org/index.php/BlenderDev/BlenderArchitecture/CustomData
Replaced TFace by MTFace:
This is the same struct, except that it does not contain color, that now
always stays separated in MCol. This was not a good design decision to
begin with, and it is needed for adding multiple color layers later. Note
that this does mean older Blender versions will not be able to read UV
coordinates from the next release, due to an SDNA limitation.
Removed DispListMesh:
This now fully replaced by DerivedMesh. To provide access to arrays of
vertices, edges and faces, like DispListMesh does. The semantics of the
DerivedMesh.getVertArray() and similar functions were changed to return
a pointer to an array if one exists, or otherwise allocate a temporary
one. On releasing the DerivedMesh, this temporary array will be removed
automatically.
Removed ssDM and meshDM DerivedMesh backends:
The ssDM backend was for DispListMesh, so that became obsolete automatically.
The meshDM backend was replaced by the custom data backend, that now figures
out which layers need to be modified, and only duplicates those.
This changes code in many places, and overall removes 2514 lines of code.
So, there's a good chance this might break some stuff, although I've been
testing it for a few days now. The good news is, adding multiple color and
uv layers should now become easy.
											
										 
											2006-11-20 04:28:02 +00:00
										 |  |  | struct CustomData; | 
					
						
							| 
									
										
										
										
											2011-02-09 02:28:11 +00:00
										 |  |  | struct DerivedMesh; | 
					
						
							|  |  |  | struct Scene; | 
					
						
							| 
									
										
										
										
											2011-10-30 09:19:07 +00:00
										 |  |  | struct MLoopUV; | 
					
						
							| 
									
										
										
										
											2012-01-17 16:31:13 +00:00
										 |  |  | struct UvVertMap; | 
					
						
							|  |  |  | struct UvMapVert; | 
					
						
							|  |  |  | struct UvElementMap; | 
					
						
							|  |  |  | struct UvElement; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 02:23:30 +00:00
										 |  |  | struct BMesh *BKE_mesh_to_bmesh(struct Mesh *me, struct Object *ob); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-30 21:30:07 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * this function recreates a tessellation. | 
					
						
							|  |  |  |  * returns number of tessellation faces. | 
					
						
							| 
									
										
										
										
											2011-12-27 08:39:55 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * use_poly_origindex sets whether or not the tessellation faces' origindex | 
					
						
							| 
									
										
										
										
											2011-12-27 08:39:55 +00:00
										 |  |  |  * layer should point to original poly indices or real poly indices. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * use_face_origindex sets the tessellation faces' origindex layer | 
					
						
							|  |  |  |  * to point to the tessellation faces themselves, not the polys. | 
					
						
							| 
									
										
										
										
											2011-12-27 08:39:55 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * if both of the above are 0, it'll use the indices of the mpolys of the MPoly | 
					
						
							|  |  |  |  * data in pdata, and ignore the origindex layer altogether. | 
					
						
							| 
									
										
										
										
											2009-08-30 21:30:07 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | int BKE_mesh_recalc_tessellation(struct CustomData *fdata, struct CustomData *ldata, struct CustomData *pdata, | 
					
						
							|  |  |  |                                  struct MVert *mvert, | 
					
						
							|  |  |  |                                  int totface, int totloop, int totpoly, | 
					
						
							|  |  |  |                                  const int do_face_normals); | 
					
						
							| 
									
										
										
										
											2009-08-30 21:30:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-27 08:39:55 +00:00
										 |  |  | /* for forwards compat only quad->tri polys to mface, skip ngons.
 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | int BKE_mesh_mpoly_to_mface(struct CustomData *fdata, struct CustomData *ldata, | 
					
						
							|  |  |  |                             struct CustomData *pdata, int totface, int totloop, int totpoly); | 
					
						
							| 
									
										
										
										
											2011-12-27 08:39:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-12 06:47:59 +00:00
										 |  |  | /*calculates a face normal.*/ | 
					
						
							|  |  |  | void mesh_calc_poly_normal(struct MPoly *mpoly, struct MLoop *loopstart,  | 
					
						
							| 
									
										
										
										
											2011-11-28 23:50:40 +00:00
										 |  |  |                            struct MVert *mvarray, float no[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_calc_poly_normal_coords(struct MPoly *mpoly, struct MLoop *loopstart, | 
					
						
							|  |  |  |                                       const float (*vertex_coords)[3], float no[3]); | 
					
						
							| 
									
										
										
										
											2012-01-04 14:42:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_calc_poly_center(struct MPoly *mpoly, struct MLoop *loopstart, | 
					
						
							|  |  |  |                                struct MVert *mvarray, float cent[3]); | 
					
						
							| 
									
										
										
										
											2009-09-12 06:47:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | float BKE_mesh_calc_poly_area(struct MPoly *mpoly, struct MLoop *loopstart, | 
					
						
							|  |  |  |                               struct MVert *mvarray, float polynormal[3]); | 
					
						
							| 
									
										
										
										
											2011-11-29 02:58:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-28 23:08:40 +00:00
										 |  |  | /* Find the index of the loop in 'poly' which references vertex,
 | 
					
						
							| 
									
										
										
										
											2012-03-03 20:19:11 +00:00
										 |  |  |  * returns -1 if not found */ | 
					
						
							| 
									
										
										
										
											2012-02-28 23:08:40 +00:00
										 |  |  | int poly_find_loop_from_vert(const struct MPoly *poly, | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  |                              const struct MLoop *loopstart, | 
					
						
							|  |  |  |                              unsigned vert); | 
					
						
							| 
									
										
										
										
											2012-02-28 23:08:40 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Fill 'adj_r' with the loop indices in 'poly' adjacent to the
 | 
					
						
							| 
									
										
										
										
											2012-03-03 20:19:11 +00:00
										 |  |  |  * vertex. Returns the index of the loop matching vertex, or -1 if the | 
					
						
							|  |  |  |  * vertex is not in 'poly' */ | 
					
						
							| 
									
										
										
										
											2012-02-28 23:08:40 +00:00
										 |  |  | int poly_get_adj_loops_from_vert(unsigned adj_r[3], const struct MPoly *poly, | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  |                                  const struct MLoop *mloop, unsigned vert); | 
					
						
							| 
									
										
										
										
											2012-02-28 23:08:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 06:31:14 +00:00
										 |  |  | /* update the hide flag for edges and polys from the corresponding
 | 
					
						
							| 
									
										
										
										
											2012-04-22 11:54:53 +00:00
										 |  |  |  * flag in verts */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_flush_hidden_from_verts(const struct MVert *mvert, | 
					
						
							|  |  |  |                                       const struct MLoop *mloop, | 
					
						
							|  |  |  |                                       struct MEdge *medge, int totedge, | 
					
						
							|  |  |  |                                       struct MPoly *mpoly, int totpoly); | 
					
						
							| 
									
										
										
										
											2012-03-14 06:31:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_unlink(struct Mesh *me); | 
					
						
							| 
									
										
										
										
											2012-05-05 14:03:12 +00:00
										 |  |  | void BKE_mesh_free(struct Mesh *me, int unlink); | 
					
						
							| 
									
										
										
										
											2012-05-05 16:03:57 +00:00
										 |  |  | struct Mesh *BKE_mesh_add(const char *name); | 
					
						
							| 
									
										
										
										
											2012-05-05 14:03:12 +00:00
										 |  |  | struct Mesh *BKE_mesh_copy(struct Mesh *me); | 
					
						
							| 
									
										
										
										
											2011-12-06 09:28:25 +00:00
										 |  |  | void mesh_update_customdata_pointers(struct Mesh *me, const short do_ensure_tess_cd); | 
					
						
							| 
									
										
										
										
											2009-08-30 21:30:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 14:03:12 +00:00
										 |  |  | void BKE_mesh_make_local(struct Mesh *me); | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_boundbox_calc(struct Mesh *me, float *loc, float *size); | 
					
						
							|  |  |  | void BKE_mesh_texspace_calc(struct Mesh *me); | 
					
						
							|  |  |  | float *BKE_mesh_orco_verts_get(struct Object *ob); | 
					
						
							|  |  |  | void   BKE_mesh_orco_verts_transform(struct Mesh *me, float (*orco)[3], int totvert, int invert); | 
					
						
							| 
									
										
										
										
											2008-01-29 19:49:03 +00:00
										 |  |  | int test_index_face(struct MFace *mface, struct CustomData *mfdata, int mfindex, int nr); | 
					
						
							| 
									
										
										
										
											2012-05-05 16:03:57 +00:00
										 |  |  | struct Mesh *BKE_mesh_from_object(struct Object *ob); | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | void set_mesh(struct Object *ob, struct Mesh *me); | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_from_metaball(struct ListBase *lb, struct Mesh *me); | 
					
						
							|  |  |  | int  BKE_mesh_nurbs_to_mdata(struct Object *ob, struct MVert **allvert, int *totvert, | 
					
						
							|  |  |  |                              struct MEdge **alledge, int *totedge, struct MLoop **allloop, struct MPoly **allpoly, | 
					
						
							|  |  |  |                              int *totloop, int *totpoly); | 
					
						
							|  |  |  | int BKE_mesh_nurbs_to_mdata_customdb(struct Object *ob, struct ListBase *dispbase, struct MVert **allvert, int *_totvert, | 
					
						
							|  |  |  |                                      struct MEdge **alledge, int *_totedge, struct MLoop **allloop, struct MPoly **allpoly, | 
					
						
							|  |  |  |                                      int *_totloop, int *_totpoly); | 
					
						
							|  |  |  | void BKE_mesh_from_nurbs(struct Object *ob); | 
					
						
							|  |  |  | void BKE_mesh_from_curve(struct Scene *scene, struct Object *ob); | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | void free_dverts(struct MDeformVert *dvert, int totvert); | 
					
						
							|  |  |  | void copy_dverts(struct MDeformVert *dst, struct MDeformVert *src, int totvert); /* __NLA */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_delete_material_index(struct Mesh *me, short index); | 
					
						
							|  |  |  | void BKE_mesh_smooth_flag_set(struct Object *meshOb, int enableSmooth); | 
					
						
							| 
									
										
										
										
											2012-03-27 01:28:25 +00:00
										 |  |  | void BKE_mesh_convert_mfaces_to_mpolys(struct Mesh *mesh); | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_calc_normals_tessface(struct MVert *mverts, int numVerts, struct MFace *mfaces, int numFaces, float (*faceNors_r)[3]); | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-03 20:19:11 +00:00
										 |  |  | /* used for unit testing; compares two meshes, checking only
 | 
					
						
							|  |  |  |  * differences we care about.  should be usable with leaf's | 
					
						
							|  |  |  |  * testing framework I get RNA work done, will use hackish | 
					
						
							|  |  |  |  * testing code for now.*/ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | const char *BKE_mesh_cmp(struct Mesh *me1, struct Mesh *me2, float thresh); | 
					
						
							| 
									
										
										
										
											2010-10-27 02:22:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | struct BoundBox *BKE_mesh_boundbox_get(struct Object *ob); | 
					
						
							|  |  |  | void BKE_mesh_texspace_get(struct Mesh *me, float r_loc[3], float r_rot[3], float r_size[3]); | 
					
						
							| 
									
										
										
										
											2005-07-14 18:04:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-09-22 17:52:41 +00:00
										 |  |  | /* if old, it converts mface->edcode to edge drawflags */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_make_edges(struct Mesh *me, int old); | 
					
						
							| 
									
										
										
										
											2011-02-09 15:13:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_strip_loose_faces(struct Mesh *me); /* Needed for compatibility (some old read code). */ | 
					
						
							|  |  |  | void BKE_mesh_strip_loose_polysloops(struct Mesh *me); | 
					
						
							|  |  |  | void BKE_mesh_strip_loose_edges(struct Mesh *me); | 
					
						
							| 
									
										
										
										
											2004-07-08 20:38:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | /* Calculate vertex and face normals, face normals are returned in *faceNors_r if non-NULL
 | 
					
						
							|  |  |  |  * and vertex normals are stored in actual mverts. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_calc_normals_mapping( | 
					
						
							| 
									
										
										
										
											2012-01-06 00:08:37 +00:00
										 |  |  |         struct MVert *mverts, int numVerts, | 
					
						
							|  |  |  |         struct MLoop *mloop, struct MPoly *mpolys, int numLoops, int numPolys, float (*polyNors_r)[3], | 
					
						
							|  |  |  |         struct MFace *mfaces, int numFaces, int *origIndexFace, float (*faceNors_r)[3]); | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | /* extended version of 'BKE_mesh_calc_normals' with option not to calc vertex normals */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_calc_normals_mapping_ex( | 
					
						
							| 
									
										
										
										
											2012-01-06 00:45:07 +00:00
										 |  |  |         struct MVert *mverts, int numVerts, | 
					
						
							|  |  |  |         struct MLoop *mloop, struct MPoly *mpolys, int numLoops, int numPolys, float (*polyNors_r)[3], | 
					
						
							| 
									
										
										
										
											2012-01-06 00:08:37 +00:00
										 |  |  |         struct MFace *mfaces, int numFaces, int *origIndexFace, float (*faceNors_r)[3], | 
					
						
							|  |  |  |         const short only_face_normals); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_calc_normals( | 
					
						
							| 
									
										
										
										
											2012-01-06 00:45:07 +00:00
										 |  |  |         struct MVert *mverts, int numVerts, | 
					
						
							|  |  |  |         struct MLoop *mloop, struct MPoly *mpolys, | 
					
						
							|  |  |  |         int numLoops, int numPolys, float (*polyNors_r)[3]); | 
					
						
							| 
									
										
										
										
											2005-07-17 20:12:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | /* Return a newly MEM_malloc'd array of all the mesh vertex locations
 | 
					
						
							|  |  |  |  * (_numVerts_r_ may be NULL) */ | 
					
						
							| 
									
										
										
										
											2005-07-22 17:03:50 +00:00
										 |  |  | float (*mesh_getVertexCos(struct Mesh *me, int *numVerts_r))[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-10 11:36:57 +00:00
										 |  |  | /* map from uv vertex to face (for select linked, stitch, uv suburf) */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-10 12:26:36 +00:00
										 |  |  | /* UvVertMap */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | #define STD_UV_CONNECT_LIMIT  0.0001f
 | 
					
						
							| 
									
										
										
										
											2008-03-07 15:38:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-10 12:26:36 +00:00
										 |  |  | typedef struct UvVertMap { | 
					
						
							|  |  |  | 	struct UvMapVert **vert; | 
					
						
							|  |  |  | 	struct UvMapVert *buf; | 
					
						
							|  |  |  | } UvVertMap; | 
					
						
							| 
									
										
										
										
											2006-01-10 11:36:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | typedef struct UvMapVert { | 
					
						
							|  |  |  | 	struct UvMapVert *next; | 
					
						
							|  |  |  | 	unsigned int f; | 
					
						
							| 
									
										
										
										
											2008-03-12 19:55:37 +00:00
										 |  |  | 	unsigned char tfindex, separate, flag; | 
					
						
							| 
									
										
										
										
											2006-01-10 11:36:57 +00:00
										 |  |  | } UvMapVert; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-06 19:25:12 +00:00
										 |  |  | /* UvElement stores per uv information so that we can quickly access information for a uv.
 | 
					
						
							|  |  |  |  * it is actually an improved UvMapVert, including an island and a direct pointer to the face | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * to avoid initializing face arrays */ | 
					
						
							| 
									
										
										
										
											2012-01-17 16:31:13 +00:00
										 |  |  | typedef struct UvElement { | 
					
						
							|  |  |  | 	/* Next UvElement corresponding to same vertex */ | 
					
						
							|  |  |  | 	struct UvElement *next; | 
					
						
							|  |  |  | 	/* Face the element belongs to */ | 
					
						
							| 
									
										
										
										
											2012-01-17 21:08:25 +00:00
										 |  |  | 	struct BMFace *face; | 
					
						
							| 
									
										
										
										
											2012-01-17 16:31:13 +00:00
										 |  |  | 	/* Index in the editFace of the uv */ | 
					
						
							| 
									
										
										
										
											2012-02-21 19:41:38 +00:00
										 |  |  | 	struct BMLoop *l; | 
					
						
							| 
									
										
										
										
											2012-02-22 00:06:15 +00:00
										 |  |  | 	/* index in loop. */ | 
					
						
							|  |  |  | 	unsigned short tfindex; | 
					
						
							| 
									
										
										
										
											2012-01-17 16:31:13 +00:00
										 |  |  | 	/* Whether this element is the first of coincident elements */ | 
					
						
							|  |  |  | 	unsigned char separate; | 
					
						
							|  |  |  | 	/* general use flag */ | 
					
						
							|  |  |  | 	unsigned char flag; | 
					
						
							|  |  |  | 	/* If generating element map with island sorting, this stores the island index */ | 
					
						
							|  |  |  | 	unsigned short island; | 
					
						
							|  |  |  | } UvElement; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-06 19:25:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* UvElementMap is a container for UvElements of a mesh. It stores some UvElements belonging to the
 | 
					
						
							|  |  |  |  * same uv island in sequence and the number of uvs per island so it is possible to access all uvs | 
					
						
							|  |  |  |  * belonging to an island directly by iterating through the buffer. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct UvElementMap { | 
					
						
							|  |  |  | 	/* address UvElements by their vertex */ | 
					
						
							|  |  |  | 	struct UvElement **vert; | 
					
						
							|  |  |  | 	/* UvElement Store */ | 
					
						
							|  |  |  | 	struct UvElement *buf; | 
					
						
							|  |  |  | 	/* Total number of UVs in the layer. Useful to know */ | 
					
						
							|  |  |  | 	int totalUVs; | 
					
						
							|  |  |  | 	/* Number of Islands in the mesh */ | 
					
						
							|  |  |  | 	int totalIslands; | 
					
						
							|  |  |  | 	/* Stores the starting index in buf where each island begins */ | 
					
						
							|  |  |  | 	int *islandIndices; | 
					
						
							|  |  |  | } UvElementMap; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-17 16:31:13 +00:00
										 |  |  | /* invalid island index is max short. If any one has the patience
 | 
					
						
							|  |  |  |  * to make that many islands, he can bite me :p */ | 
					
						
							|  |  |  | #define INVALID_ISLAND 0xFFFF
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | UvVertMap *BKE_mesh_uv_vert_map_make(struct MPoly *mpoly, struct MLoop *mloop, struct MLoopUV *mloopuv, | 
					
						
							|  |  |  |                                      unsigned int totpoly, unsigned int totvert, int selected, float *limit); | 
					
						
							|  |  |  | UvMapVert *BKE_mesh_uv_vert_map_get_vert(UvVertMap *vmap, unsigned int v); | 
					
						
							|  |  |  | void       BKE_mesh_uv_vert_map_free(UvVertMap *vmap); | 
					
						
							| 
									
										
										
										
											2006-01-10 11:36:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-21 22:40:28 +00:00
										 |  |  | /* Connectivity data */ | 
					
						
							| 
									
										
										
										
											2012-03-17 04:41:36 +00:00
										 |  |  | typedef struct MeshElemMap { | 
					
						
							|  |  |  | 	int *indices; | 
					
						
							|  |  |  | 	int count; | 
					
						
							|  |  |  | } MeshElemMap; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-01-21 22:40:28 +00:00
										 |  |  | typedef struct IndexNode { | 
					
						
							|  |  |  | 	struct IndexNode *next, *prev; | 
					
						
							|  |  |  | 	int index; | 
					
						
							|  |  |  | } IndexNode; | 
					
						
							| 
									
										
										
										
											2012-03-17 04:41:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void create_vert_poly_map(MeshElemMap **map, int **mem, | 
					
						
							|  |  |  |                           const struct MPoly *mface, const struct MLoop *mloop, | 
					
						
							|  |  |  |                           int totvert, int totface, int totloop); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-12-30 21:11:40 +00:00
										 |  |  | void create_vert_edge_map(struct ListBase **map, IndexNode **mem, const struct MEdge *medge, | 
					
						
							| 
									
										
										
										
											2011-11-11 13:09:14 +00:00
										 |  |  |                           const int totvert, const int totedge); | 
					
						
							| 
									
										
										
										
											2009-01-21 22:40:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | /* vertex level transformations & checks (no derived mesh) */ | 
					
						
							| 
									
										
										
										
											2007-09-18 19:39:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | int BKE_mesh_minmax(struct Mesh *me, float r_min[3], float r_max[3]); | 
					
						
							|  |  |  | int BKE_mesh_center_median(struct Mesh *me, float cent[3]); | 
					
						
							|  |  |  | int BKE_mesh_center_bounds(struct Mesh *me, float cent[3]); | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_translate(struct Mesh *me, float offset[3], int do_keys); | 
					
						
							| 
									
										
										
										
											2007-09-18 19:39:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-09 02:28:11 +00:00
										 |  |  | /* mesh_validate.c */ | 
					
						
							| 
									
										
										
										
											2012-03-15 20:10:07 +00:00
										 |  |  | /* XXX Loop v/e are unsigned, so using max uint_32 value as invalid marker... */ | 
					
						
							|  |  |  | #define INVALID_LOOP_EDGE_MARKER 4294967295u
 | 
					
						
							| 
									
										
										
										
											2011-12-08 04:51:03 +00:00
										 |  |  | int BKE_mesh_validate_arrays( | 
					
						
							| 
									
										
										
										
											2012-03-15 20:10:07 +00:00
										 |  |  |         struct Mesh *me, | 
					
						
							| 
									
										
										
										
											2011-12-08 04:51:03 +00:00
										 |  |  |         struct MVert *mverts, unsigned int totvert, | 
					
						
							|  |  |  |         struct MEdge *medges, unsigned int totedge, | 
					
						
							| 
									
										
										
										
											2012-03-15 20:10:07 +00:00
										 |  |  |         struct MLoop *mloops, unsigned int totloop, | 
					
						
							|  |  |  |         struct MPoly *mpolys, unsigned int totpoly, | 
					
						
							| 
									
										
										
										
											2011-12-08 04:51:03 +00:00
										 |  |  |         struct MDeformVert *dverts, /* assume totvert length */ | 
					
						
							|  |  |  |         const short do_verbose, const short do_fixes); | 
					
						
							| 
									
										
										
										
											2011-02-10 09:29:31 +00:00
										 |  |  | int BKE_mesh_validate(struct Mesh *me, int do_verbose); | 
					
						
							|  |  |  | int BKE_mesh_validate_dm(struct DerivedMesh *dm); | 
					
						
							| 
									
										
										
										
											2011-02-09 02:28:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-09 15:13:20 +00:00
										 |  |  | void BKE_mesh_calc_edges(struct Mesh *mesh, int update); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-09 21:11:51 +00:00
										 |  |  | void BKE_mesh_ensure_navmesh(struct Mesh *me); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 19:11:09 +00:00
										 |  |  | void BKE_mesh_tessface_calc(struct Mesh *mesh); | 
					
						
							|  |  |  | void BKE_mesh_tessface_ensure(struct Mesh *mesh); | 
					
						
							|  |  |  | void BKE_mesh_tessface_clear(struct Mesh *mesh); | 
					
						
							| 
									
										
										
										
											2012-02-05 07:12:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												Fix [#30234] Various problems with CD layers and tesselation, related to modifiers stack.
Should also fix [#30266], [#29451], and partly [#30316].
Here are the changes made by this commit:
* It adds a "dirty" flag to DerivedMesh struct (for now, only DM_DIRTY_TESS_CDLAYERS, but more might be added as needed).
* It adds a new func, DM_update_tessface_data, which assumes tessfaces themselves are valid, but updates tessellated customdata from their poly/loop counter parts.
* At end of modstack, when valid tessellated faces are present in finaldm , but the cdlayers dirty flag is set, call that function (instead of recomputing the whole tessellation).
* Edits to the codes concerned (UVProject, DynamicPaint, and Subsurf modifiers).
* Also add to subsurf dm generation code the creation of a CD_POLYINDEX layer (mandatory for DM_update_tessface_data to work well, and imho all tessellated dm should have one).
Note: some pieces of old code are just #if 0’ed, will clean them later.
											
										 
											2012-03-18 22:06:57 +00:00
										 |  |  | /* Convert a triangle or quadrangle of loop/poly data to tessface data */ | 
					
						
							| 
									
										
										
										
											2012-05-05 21:28:12 +00:00
										 |  |  | void BKE_mesh_loops_to_mface_corners(struct CustomData *fdata, struct CustomData *ldata, | 
					
						
							|  |  |  |                                      struct CustomData *pdata, int lindex[4], int findex, | 
					
						
							|  |  |  |                                      const int polyindex, const int mf_len, | 
					
						
							|  |  |  |                                      const int numTex, const int numCol, const int hasPCol, const int hasOrigSpace); | 
					
						
							| 
									
										
										
										
											2011-03-25 00:32:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 14:58:38 +00:00
										 |  |  | void BKE_mesh_poly_calc_angles(struct MVert *mvert, struct MLoop *mloop, | 
					
						
							|  |  |  |                                struct MPoly *mp, float angles[]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #endif /* __BKE_MESH_H__ */
 |