Modifiers: ported Triangulate DerivedMesh → Mesh
Reviewers: sybren Differential Revision: https://developer.blender.org/D3237
This commit is contained in:
		| @@ -25,40 +25,45 @@ | |||||||
|  *  \ingroup modifiers |  *  \ingroup modifiers | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | #include "DNA_mesh_types.h" | ||||||
|  | #include "DNA_meshdata_types.h" | ||||||
| #include "DNA_object_types.h" | #include "DNA_object_types.h" | ||||||
|  |  | ||||||
| #include "BLI_utildefines.h" | #include "BLI_utildefines.h" | ||||||
|  |  | ||||||
| #include "BKE_cdderivedmesh.h" |  | ||||||
| #include "BKE_modifier.h" | #include "BKE_modifier.h" | ||||||
|  | #include "BKE_mesh.h" | ||||||
|  |  | ||||||
| #include "bmesh.h" | #include "bmesh.h" | ||||||
| #include "bmesh_tools.h" | #include "bmesh_tools.h" | ||||||
|  |  | ||||||
| #include "MOD_modifiertypes.h" | #include "MOD_modifiertypes.h" | ||||||
|  |  | ||||||
| static DerivedMesh *triangulate_dm(DerivedMesh *dm, const int quad_method, const int ngon_method) | static Mesh *triangulate_mesh(Mesh *mesh, const int quad_method, const int ngon_method) | ||||||
| { | { | ||||||
| 	DerivedMesh *result; | 	Mesh *result; | ||||||
| 	BMesh *bm; | 	BMesh *bm; | ||||||
| 	int total_edges, i; | 	int total_edges, i; | ||||||
| 	MEdge *me; | 	MEdge *me; | ||||||
|  |  | ||||||
| 	bm = DM_to_bmesh(dm, true); | 	bm = BKE_mesh_to_bmesh_ex( | ||||||
|  | 	         mesh, | ||||||
|  | 	         &((struct BMeshCreateParams){0}), | ||||||
|  | 	         &((struct BMeshFromMeshParams){.calc_face_normal = true,})); | ||||||
|  |  | ||||||
| 	BM_mesh_triangulate(bm, quad_method, ngon_method, false, NULL, NULL, NULL); | 	BM_mesh_triangulate(bm, quad_method, ngon_method, false, NULL, NULL, NULL); | ||||||
|  |  | ||||||
| 	result = CDDM_from_bmesh(bm, false); | 	result = BKE_bmesh_to_mesh_nomain(bm, &((struct BMeshToMeshParams){0})); | ||||||
| 	BM_mesh_free(bm); | 	BM_mesh_free(bm); | ||||||
|  |  | ||||||
| 	total_edges = result->getNumEdges(result); | 	total_edges = result->totedge; | ||||||
| 	me = CDDM_get_edges(result); | 	me = result->medge; | ||||||
|  |  | ||||||
| 	/* force drawing of all edges (seems to be omitted in CDDM_from_bmesh) */ | 	/* force drawing of all edges (seems to be omitted in CDDM_from_bmesh) */ | ||||||
| 	for (i = 0; i < total_edges; i++, me++) | 	for (i = 0; i < total_edges; i++, me++) | ||||||
| 		me->flag |= ME_EDGEDRAW | ME_EDGERENDER; | 		me->flag |= ME_EDGEDRAW | ME_EDGERENDER; | ||||||
|  |  | ||||||
| 	result->dirty |= DM_DIRTY_NORMALS; | 	result->runtime.cd_dirty_vert |= CD_MASK_NORMAL; | ||||||
|  |  | ||||||
| 	return result; | 	return result; | ||||||
| } | } | ||||||
| @@ -74,14 +79,14 @@ static void initData(ModifierData *md) | |||||||
| 	tmd->ngon_method = MOD_TRIANGULATE_NGON_BEAUTY; | 	tmd->ngon_method = MOD_TRIANGULATE_NGON_BEAUTY; | ||||||
| } | } | ||||||
|  |  | ||||||
| static DerivedMesh *applyModifier(ModifierData *md, | static Mesh *applyModifier(ModifierData *md, | ||||||
|                            const ModifierEvalContext *UNUSED(ctx), |                            const ModifierEvalContext *UNUSED(ctx), | ||||||
|                                   DerivedMesh *dm) |                            Mesh *mesh) | ||||||
| { | { | ||||||
| 	TriangulateModifierData *tmd = (TriangulateModifierData *)md; | 	TriangulateModifierData *tmd = (TriangulateModifierData *)md; | ||||||
| 	DerivedMesh *result; | 	Mesh *result; | ||||||
| 	if (!(result = triangulate_dm(dm, tmd->quad_method, tmd->ngon_method))) { | 	if (!(result = triangulate_mesh(mesh, tmd->quad_method, tmd->ngon_method))) { | ||||||
| 		return dm; | 		return mesh; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return result; | 	return result; | ||||||
| @@ -104,14 +109,14 @@ ModifierTypeInfo modifierType_Triangulate = { | |||||||
| 	/* deformMatrices_DM */ NULL, | 	/* deformMatrices_DM */ NULL, | ||||||
| 	/* deformVertsEM_DM */  NULL, | 	/* deformVertsEM_DM */  NULL, | ||||||
| 	/* deformMatricesEM_DM*/NULL, | 	/* deformMatricesEM_DM*/NULL, | ||||||
| 	/* applyModifier_DM */  applyModifier, | 	/* applyModifier_DM */  NULL, | ||||||
| 	/* applyModifierEM_DM */NULL, | 	/* applyModifierEM_DM */NULL, | ||||||
|  |  | ||||||
| 	/* deformVerts */       NULL, | 	/* deformVerts */       NULL, | ||||||
| 	/* deformMatrices */    NULL, | 	/* deformMatrices */    NULL, | ||||||
| 	/* deformVertsEM */     NULL, | 	/* deformVertsEM */     NULL, | ||||||
| 	/* deformMatricesEM */  NULL, | 	/* deformMatricesEM */  NULL, | ||||||
| 	/* applyModifier */     NULL, | 	/* applyModifier */     applyModifier, | ||||||
| 	/* applyModifierEM */   NULL, | 	/* applyModifierEM */   NULL, | ||||||
|  |  | ||||||
| 	/* initData */          initData, | 	/* initData */          initData, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user