Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/source
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2013-05-08 18:01:38 +0400
committerCampbell Barton <ideasman42@gmail.com>2013-05-08 18:01:38 +0400
commit7dbf6d513e785f2b3101b555c983a19245c94620 (patch)
tree72e92954e52a1186b709cd9057f4258b95f1448e /source
parent8193d83cd99a56709609e41f1f4eb28db8aa2d29 (diff)
mesh dissolve vertices: option to split off corners of surrounding faces, makes the result more localized to the area around the vertex.
Diffstat (limited to 'source')
-rw-r--r--source/blender/bmesh/intern/bmesh_opdefines.c1
-rw-r--r--source/blender/bmesh/operators/bmo_dissolve.c24
-rw-r--r--source/blender/editors/mesh/editmesh_tools.c7
3 files changed, 30 insertions, 2 deletions
diff --git a/source/blender/bmesh/intern/bmesh_opdefines.c b/source/blender/bmesh/intern/bmesh_opdefines.c
index 587696268b1..77e45648813 100644
--- a/source/blender/bmesh/intern/bmesh_opdefines.c
+++ b/source/blender/bmesh/intern/bmesh_opdefines.c
@@ -842,6 +842,7 @@ static BMOpDefine bmo_dissolve_verts_def = {
"dissolve_verts",
/* slots_in */
{{"verts", BMO_OP_SLOT_ELEMENT_BUF, {BM_VERT}},
+ {"use_face_split", BMO_OP_SLOT_BOOL},
{{'\0'}},
},
{{{'\0'}}}, /* no output */
diff --git a/source/blender/bmesh/operators/bmo_dissolve.c b/source/blender/bmesh/operators/bmo_dissolve.c
index e2a3cf025aa..3023071175a 100644
--- a/source/blender/bmesh/operators/bmo_dissolve.c
+++ b/source/blender/bmesh/operators/bmo_dissolve.c
@@ -359,10 +359,32 @@ void bmo_dissolve_verts_exec(BMesh *bm, BMOperator *op)
BMIter iter, fiter;
BMVert *v;
BMFace *f;
- /* int i; */
+
+ const bool use_face_split = BMO_slot_bool_get(op->slots_in, "use_face_split");
+
BMO_slot_buffer_flag_enable(bm, op->slots_in, "verts", BM_VERT, VERT_MARK);
+ if (use_face_split) {
+ BMIter liter;
+ BM_ITER_MESH (v, &iter, bm, BM_VERTS_OF_MESH) {
+ if (BMO_elem_flag_test(bm, v, VERT_MARK)) {
+ if (BM_vert_edge_count(v) > 2) {
+ BMLoop *l;
+ BM_ITER_ELEM (l, &liter, v, BM_LOOPS_OF_VERT) {
+ if (l->f->len > 3) {
+ if (BMO_elem_flag_test(bm, l->next->v, VERT_MARK) == 0 &&
+ BMO_elem_flag_test(bm, l->prev->v, VERT_MARK) == 0)
+ {
+ BM_face_split(bm, l->f, l->next->v, l->prev->v, NULL, NULL, true);
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+
for (v = BM_iter_new(&iter, bm, BM_VERTS_OF_MESH, NULL); v; v = BM_iter_step(&iter)) {
if (BMO_elem_flag_test(bm, v, VERT_MARK)) {
/* check if it's a two-valence ver */
diff --git a/source/blender/editors/mesh/editmesh_tools.c b/source/blender/editors/mesh/editmesh_tools.c
index 644b6137714..4b325d2212f 100644
--- a/source/blender/editors/mesh/editmesh_tools.c
+++ b/source/blender/editors/mesh/editmesh_tools.c
@@ -2803,7 +2803,9 @@ static int edbm_dissolve_verts_exec(bContext *C, wmOperator *op)
Object *obedit = CTX_data_edit_object(C);
BMEditMesh *em = BKE_editmesh_from_object(obedit);
- if (!EDBM_op_callf(em, op, "dissolve_verts verts=%hv", BM_ELEM_SELECT))
+ const bool use_face_split = RNA_boolean_get(op->ptr, "use_face_split");
+
+ if (!EDBM_op_callf(em, op, "dissolve_verts verts=%hv use_face_split=%b", BM_ELEM_SELECT, use_face_split))
return OPERATOR_CANCELLED;
EDBM_update_generic(em, true, true);
@@ -2824,6 +2826,9 @@ void MESH_OT_dissolve_verts(wmOperatorType *ot)
/* flags */
ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+
+ RNA_def_boolean(ot->srna, "use_face_split", 0, "Face Split",
+ "Split off face corners to maintain surrounding geometry");
}
static int edbm_dissolve_edges_exec(bContext *C, wmOperator *op)