| 
									
										
										
										
											2012-11-19 20:40:08 +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 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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 | 
					
						
							| 
									
										
										
										
											2020-05-09 17:14:35 +10:00
										 |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup modifiers | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-28 18:03:48 +01:00
										 |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-25 11:39:14 +01:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | #include "BLT_translation.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-09 16:00:12 +02:00
										 |  |  | #include "DNA_mesh_types.h"
 | 
					
						
							|  |  |  | #include "DNA_meshdata_types.h"
 | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | #include "DNA_object_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | #include "DNA_screen_types.h"
 | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | #include "BKE_context.h"
 | 
					
						
							| 
									
										
										
										
											2018-05-09 16:00:12 +02:00
										 |  |  | #include "BKE_mesh.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "BKE_modifier.h"
 | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | #include "BKE_screen.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "UI_interface.h"
 | 
					
						
							|  |  |  | #include "UI_resources.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "RNA_access.h"
 | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-23 04:22:07 +00:00
										 |  |  | #include "bmesh.h"
 | 
					
						
							|  |  |  | #include "bmesh_tools.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-01 09:06:34 +10:00
										 |  |  | #include "MOD_modifiertypes.h"
 | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | #include "MOD_ui_common.h"
 | 
					
						
							| 
									
										
										
										
											2017-08-01 09:06:34 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static Mesh *triangulate_mesh(Mesh *mesh, | 
					
						
							|  |  |  |                               const int quad_method, | 
					
						
							|  |  |  |                               const int ngon_method, | 
					
						
							|  |  |  |                               const int min_vertices, | 
					
						
							|  |  |  |                               const int flag) | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   Mesh *result; | 
					
						
							|  |  |  |   BMesh *bm; | 
					
						
							|  |  |  |   int total_edges, i; | 
					
						
							|  |  |  |   MEdge *me; | 
					
						
							| 
									
										
										
										
											2020-03-17 11:04:50 +11:00
										 |  |  |   CustomData_MeshMasks cd_mask_extra = { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       .vmask = CD_MASK_ORIGINDEX, .emask = CD_MASK_ORIGINDEX, .pmask = CD_MASK_ORIGINDEX}; | 
					
						
							| 
									
										
										
										
											2019-02-28 18:03:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   bool keep_clnors = (flag & MOD_TRIANGULATE_KEEP_CUSTOMLOOP_NORMALS) != 0; | 
					
						
							| 
									
										
										
										
											2019-02-28 18:03:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (keep_clnors) { | 
					
						
							|  |  |  |     BKE_mesh_calc_normals_split(mesh); | 
					
						
							|  |  |  |     /* We need that one to 'survive' to/from BMesh conversions. */ | 
					
						
							|  |  |  |     CustomData_clear_layer_flag(&mesh->ldata, CD_NORMAL, CD_FLAG_TEMPORARY); | 
					
						
							| 
									
										
										
										
											2020-03-17 11:04:50 +11:00
										 |  |  |     cd_mask_extra.lmask |= CD_MASK_NORMAL; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   bm = BKE_mesh_to_bmesh_ex(mesh, | 
					
						
							|  |  |  |                             &((struct BMeshCreateParams){0}), | 
					
						
							|  |  |  |                             &((struct BMeshFromMeshParams){ | 
					
						
							|  |  |  |                                 .calc_face_normal = true, | 
					
						
							| 
									
										
										
										
											2020-03-17 11:04:50 +11:00
										 |  |  |                                 .cd_mask_extra = cd_mask_extra, | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |                             })); | 
					
						
							| 
									
										
										
										
											2012-11-19 23:52:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BM_mesh_triangulate(bm, quad_method, ngon_method, min_vertices, false, NULL, NULL, NULL); | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-17 11:04:50 +11:00
										 |  |  |   result = BKE_mesh_from_bmesh_for_eval_nomain(bm, &cd_mask_extra, mesh); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BM_mesh_free(bm); | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (keep_clnors) { | 
					
						
							|  |  |  |     float(*lnors)[3] = CustomData_get_layer(&result->ldata, CD_NORMAL); | 
					
						
							|  |  |  |     BLI_assert(lnors != NULL); | 
					
						
							| 
									
										
										
										
											2019-02-28 18:03:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     BKE_mesh_set_custom_normals(result, lnors); | 
					
						
							| 
									
										
										
										
											2019-02-28 18:03:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* Do some cleanup, we do not want those temp data to stay around. */ | 
					
						
							|  |  |  |     CustomData_set_layer_flag(&mesh->ldata, CD_NORMAL, CD_FLAG_TEMPORARY); | 
					
						
							|  |  |  |     CustomData_set_layer_flag(&result->ldata, CD_NORMAL, CD_FLAG_TEMPORARY); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-02-28 18:03:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   total_edges = result->totedge; | 
					
						
							|  |  |  |   me = result->medge; | 
					
						
							| 
									
										
										
										
											2019-02-28 18:03:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* force drawing of all edges (seems to be omitted in CDDM_from_bmesh) */ | 
					
						
							|  |  |  |   for (i = 0; i < total_edges; i++, me++) { | 
					
						
							|  |  |  |     me->flag |= ME_EDGEDRAW | ME_EDGERENDER; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2012-11-20 09:04:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   result->runtime.cd_dirty_vert |= CD_MASK_NORMAL; | 
					
						
							| 
									
										
										
										
											2012-11-19 23:52:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return result; | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void initData(ModifierData *md) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   TriangulateModifierData *tmd = (TriangulateModifierData *)md; | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Enable in editmode by default */ | 
					
						
							|  |  |  |   md->mode |= eModifierMode_Editmode; | 
					
						
							|  |  |  |   tmd->quad_method = MOD_TRIANGULATE_QUAD_SHORTEDGE; | 
					
						
							|  |  |  |   tmd->ngon_method = MOD_TRIANGULATE_NGON_BEAUTY; | 
					
						
							|  |  |  |   tmd->min_vertices = 4; | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-21 13:09:41 +02:00
										 |  |  | static Mesh *modifyMesh(ModifierData *md, const ModifierEvalContext *UNUSED(ctx), Mesh *mesh) | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   TriangulateModifierData *tmd = (TriangulateModifierData *)md; | 
					
						
							|  |  |  |   Mesh *result; | 
					
						
							|  |  |  |   if (!(result = triangulate_mesh( | 
					
						
							|  |  |  |             mesh, tmd->quad_method, tmd->ngon_method, tmd->min_vertices, tmd->flag))) { | 
					
						
							|  |  |  |     return mesh; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return result; | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-02 14:13:26 -05:00
										 |  |  | static void panel_draw(const bContext *UNUSED(C), Panel *panel) | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | { | 
					
						
							|  |  |  |   uiLayout *layout = panel->layout; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   PointerRNA ob_ptr; | 
					
						
							| 
									
										
										
										
											2020-09-02 14:13:26 -05:00
										 |  |  |   PointerRNA *ptr = modifier_panel_get_property_pointers(panel, &ob_ptr); | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |   uiLayoutSetPropSep(layout, true); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-02 14:13:26 -05:00
										 |  |  |   uiItemR(layout, ptr, "quad_method", 0, NULL, ICON_NONE); | 
					
						
							|  |  |  |   uiItemR(layout, ptr, "ngon_method", 0, NULL, ICON_NONE); | 
					
						
							|  |  |  |   uiItemR(layout, ptr, "min_vertices", 0, NULL, ICON_NONE); | 
					
						
							|  |  |  |   uiItemR(layout, ptr, "keep_custom_normals", 0, NULL, ICON_NONE); | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-02 14:13:26 -05:00
										 |  |  |   modifier_panel_end(layout, ptr); | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void panelRegister(ARegionType *region_type) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   modifier_panel_register(region_type, eModifierType_Triangulate, panel_draw); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | ModifierTypeInfo modifierType_Triangulate = { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* name */ "Triangulate", | 
					
						
							|  |  |  |     /* structName */ "TriangulateModifierData", | 
					
						
							|  |  |  |     /* structSize */ sizeof(TriangulateModifierData), | 
					
						
							|  |  |  |     /* type */ eModifierTypeType_Constructive, | 
					
						
							|  |  |  |     /* flags */ eModifierTypeFlag_AcceptsMesh | eModifierTypeFlag_SupportsEditmode | | 
					
						
							|  |  |  |         eModifierTypeFlag_SupportsMapping | eModifierTypeFlag_EnableInEditmode | | 
					
						
							|  |  |  |         eModifierTypeFlag_AcceptsCVs, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-08 10:14:02 +02:00
										 |  |  |     /* copyData */ BKE_modifier_copydata_generic, | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* deformVerts */ NULL, | 
					
						
							|  |  |  |     /* deformMatrices */ NULL, | 
					
						
							|  |  |  |     /* deformVertsEM */ NULL, | 
					
						
							|  |  |  |     /* deformMatricesEM */ NULL, | 
					
						
							| 
									
										
										
										
											2020-04-21 13:09:41 +02:00
										 |  |  |     /* modifyMesh */ modifyMesh, | 
					
						
							|  |  |  |     /* modifyHair */ NULL, | 
					
						
							|  |  |  |     /* modifyPointCloud */ NULL, | 
					
						
							|  |  |  |     /* modifyVolume */ NULL, | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* initData */ initData, | 
					
						
							| 
									
										
										
										
											2019-05-01 07:40:07 +10:00
										 |  |  |     /* requiredDataMask */ NULL,  // requiredDataMask,
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* freeData */ NULL, | 
					
						
							|  |  |  |     /* isDisabled */ NULL, | 
					
						
							|  |  |  |     /* updateDepsgraph */ NULL, | 
					
						
							|  |  |  |     /* dependsOnTime */ NULL, | 
					
						
							|  |  |  |     /* dependsOnNormals */ NULL, | 
					
						
							|  |  |  |     /* foreachObjectLink */ NULL, | 
					
						
							|  |  |  |     /* foreachIDLink */ NULL, | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  |     /* foreachTexLink */ NULL, | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* freeRuntimeData */ NULL, | 
					
						
							| 
									
										
										
										
											2020-06-05 10:41:03 -04:00
										 |  |  |     /* panelRegister */ panelRegister, | 
					
						
							| 
									
										
										
										
											2020-06-15 17:37:07 +02:00
										 |  |  |     /* blendWrite */ NULL, | 
					
						
							|  |  |  |     /* blendRead */ NULL, | 
					
						
							| 
									
										
										
										
											2012-11-19 20:40:08 +00:00
										 |  |  | }; |