diff --git a/mesh_snap_utilities_line/op_line.py b/mesh_snap_utilities_line/op_line.py index 0444f0e2978a5b5952f96654bef5b514bd63ad50..eacc551be20a947c98660b1fadb975dfec77ad88 100644 --- a/mesh_snap_utilities_line/op_line.py +++ b/mesh_snap_utilities_line/op_line.py @@ -170,8 +170,28 @@ def make_line(self, bm_geom, location): break ed_list.update(get_loose_linked_edges(v2)) + ed_list = list(ed_list) + + # WORKAROUND: `edgenet_fill` only works with loose edges or boundary + # edges, so remove the other edges and create temporary elements to + # replace them. + targetmap = {} + ed_new = [] + for edge in ed_list: + if not edge.is_wire and not edge.is_boundary: + v1, v2 = edge.verts + tmp_vert = bm.verts.new(v2.co) + e1 = bm.edges.new([v1, tmp_vert]) + e2 = bm.edges.new([tmp_vert, v2]) + ed_list.remove(edge) + ed_new.append(e1) + ed_new.append(e2) + targetmap[tmp_vert] = v2 + + bmesh.ops.edgenet_fill(bm, edges=ed_list + ed_new) + if targetmap: + bmesh.ops.weld_verts(bm, targetmap=targetmap) - bmesh.ops.edgenet_fill(bm, edges=list(ed_list)) update_edit_mesh = True # print('face created')