|
Blender V5.0
|
#include "MEM_guardedalloc.h"#include "BLI_alloca.h"#include "BLI_linklist.h"#include "BLI_math_base.h"#include "BLI_math_geom.h"#include "BLI_math_matrix.h"#include "BLI_math_rotation.h"#include "BLI_math_vector.h"#include "BLI_utildefines_stack.h"#include "BKE_customdata.hh"#include "bmesh.hh"#include "intern/bmesh_private.hh"Go to the source code of this file.
Macros | |
| #define | LOOP_VISIT _FLAG_WALK |
| #define | EDGE_VISIT _FLAG_WALK |
This file contains functions for answering common Topological and geometric queries about a mesh, such as, "What is the angle between these two faces?" or, "How many faces are incident upon this vertex?" Tool authors should use the functions in this file instead of inspecting the mesh structure directly.
Definition in file bmesh_query.cc.
| #define EDGE_VISIT _FLAG_WALK |
Definition at line 773 of file bmesh_query.cc.
| #define LOOP_VISIT _FLAG_WALK |
Definition at line 772 of file bmesh_query.cc.
Definition at line 1348 of file bmesh_query.cc.
References BM_edge_calc_face_angle_ex(), DEG2RADF, and e.
Referenced by bm_vert_edge_face_angle().
BMESH EDGE/FACE ANGLE.
Calculates the angle between two faces. Assumes the face normals are correct.
Definition at line 1339 of file bmesh_query.cc.
References angle_normalized_v3v3(), BM_edge_is_manifold(), e, BMLoop::f, and BMFace::no.
Referenced by BM_edge_calc_face_angle(), bpy_bmedge_calc_face_angle(), and edbm_beautify_fill_exec().
Definition at line 1389 of file bmesh_query.cc.
References BM_edge_calc_face_angle_signed_ex(), DEG2RADF, and e.
Referenced by blender::draw::statvis_calc_sharp().
BMESH EDGE/FACE ANGLE.
Calculates the angle between two faces. Assumes the face normals are correct.
Definition at line 1379 of file bmesh_query.cc.
References angle(), angle_normalized_v3v3(), BM_edge_is_convex(), BM_edge_is_manifold(), e, BMLoop::f, and BMFace::no.
Referenced by BM_edge_calc_face_angle_signed(), bpy_bmedge_calc_face_angle_signed(), and tri_corner_test().
Definition at line 1374 of file bmesh_query.cc.
References BM_edge_calc_face_angle_with_imat3_ex(), DEG2RADF, and e.
Referenced by similar_edge_select_exec().
| float BM_edge_calc_face_angle_with_imat3_ex | ( | const BMEdge * | e, |
| const float | imat3[3][3], | ||
| float | fallback ) |
BMESH EDGE/FACE ANGLE.
Calculates the angle between two faces in world space. Assumes the face normals are correct.
Definition at line 1353 of file bmesh_query.cc.
References angle_normalized_v3v3(), BM_edge_is_manifold(), copy_v3_v3(), e, BMLoop::f, mul_transposed_m3_v3(), BMFace::no, and normalize_v3().
Referenced by BM_edge_calc_face_angle_with_imat3().
BMESH EDGE/FACE TANGENT.
Calculate the tangent at this loop corner or fallback to the face normal on straight lines. This vector always points inward into the face.
BM_edge_calc_face_tangent
| e | |
| e_loop | The loop to calculate the tangent at, used to get the face and winding direction. |
| r_tangent | The loop corner tangent to set |
Definition at line 1394 of file bmesh_query.cc.
References BM_edge_ordered_verts_ex(), BMVert::co, cross_v3_v3v3(), e, BMLoop::f, BMFace::no, normalize_v3(), sub_v3_v3v3(), and v2.
Referenced by bm_vert_boundary_tangent(), bm_vert_calc_surface_tangent(), bmo_face_inset_individual(), bmo_inset_region_exec(), and bpy_bmedge_calc_tangent().
Returns edge length
Definition at line 536 of file bmesh_query.cc.
References e, and len_v3v3().
Referenced by bevel_vert_construct(), bm_decim_build_edge_cost_single(), BM_face_calc_center_median_weighted(), bm_interior_face_group_calc_cost(), BM_vert_calc_median_tagged_edge_length(), bmo_face_inset_individual(), bmo_inset_region_exec(), edbm_calc_loop_co(), EDBM_select_interior_faces(), geometry_collide_offset(), offset_meet_lines_percent_or_absolute(), and vertex_collide_offset().
Returns edge length squared (for comparisons)
Definition at line 541 of file bmesh_query.cc.
References e, and len_squared_v3v3().
Referenced by bm_edge_calc_rotate_cost(), bm_edge_length_cmp(), bm_edge_sort_length_cb(), bmo_dissolve_degenerate_exec(), edbm_polybuild_face_at_cursor_invoke(), blender::ed::transform::getTransformOrientation_ex(), blender::bke::pbvh::long_edge_queue_edge_add(), blender::bke::pbvh::long_edge_queue_edge_add_recursive(), blender::bke::pbvh::long_edge_queue_face_add(), blender::bke::pbvh::long_edge_queue_priority(), blender::bke::pbvh::short_edge_queue_edge_add(), and blender::bke::pbvh::short_edge_queue_priority().
Returns the edge existing between v_a and v_b, or nullptr if there isn't one.
Definition at line 1564 of file bmesh_query.cc.
References BLI_assert, BM_VERT, BM_vert_in_edge(), bmesh_disk_edge_next(), BMVert::e, BMVert::head, and BMHeader::htype.
Referenced by bev_rebuild_polygon(), bevel_build_edge_polygons(), BKE_mesh_remesh_voxel_fix_poles(), BM_edge_create(), BM_edge_rotate(), BM_edge_rotate_check_degenerate(), BM_edgeloop_edges_get(), bm_edgeloop_flag_set(), bm_edgenet_path_calc_best(), bm_edgering_pair_order(), bm_edgering_pair_order_is_flipped(), BM_edges_from_verts(), bm_face_connect_verts(), BM_face_create_ngon_verts(), BM_face_other_vert_loop(), bm_face_split_edge_find(), BM_face_split_edgenet_connect_islands(), bm_grid_fill(), bm_isect_edge_tri(), bm_isect_tri_tri(), bm_loop_pair_from_verts(), BM_mesh_intersect(), BM_mesh_intersect_edges(), BM_mesh_wireframe(), bm_vert_connect_select_history(), bm_vert_loop_pair(), BM_vert_splice_check_double(), bmesh_kernel_join_edge_kill_vert(), bmesh_kernel_join_vert_kill_edge(), bmo_extrude_face_region_exec(), bmo_subdivide_edges_exec(), bmo_triangle_fill_exec(), bmo_weld_verts_exec(), bmw_EdgeLoopWalker_step(), bpy_bm_utils_vert_splice(), bpy_bmedgeseq_get__method(), bpy_bmedgeseq_new(), bridge_loop_pair(), build_hull(), edbm_add_edge_face_exec__tricky_extend_sel(), EDBM_verts_mirror_get_edge(), blender::ed::transform::getTransformOrientation_ex(), is_vertex_diagonal(), knife_add_single_cut(), knife_make_face_cuts(), blender::bke::pbvh::merge_face_edge_data(), blender::bke::pbvh::merge_flap_edge_data(), blender::bke::pbvh::pbvh_bmesh_collapse_short_edges(), blender::bke::pbvh::pbvh_bmesh_subdivide_long_edges(), remdoubles_createface(), blender::ed::transform::transform_mesh_edge_slide_data_create(), and weld_cross_attrs_copy().
| int BM_edge_face_count | ( | const BMEdge * | e | ) |
Returns the number of faces around this edge
Definition at line 637 of file bmesh_query.cc.
References count, e, and BMLoop::radial_next.
Referenced by bevel_vert_construct(), BKE_mesh_remesh_voxel_fix_poles(), bm_uidwalk_init_from_edge(), bmw_NonManifoldedgeWalker_begin(), bmw_NonManifoldedgeWalker_step(), find_bevel_edge_order(), blender::bke::pbvh::pbvh_bmesh_edge_loops(), similar_edge_select_exec(), blender::bke::pbvh::try_merge_flap_edge_data_before_dissolve(), and verg_radial().
| int BM_edge_face_count_at_most | ( | const BMEdge * | e, |
| const int | count_max ) |
Definition at line 653 of file bmesh_query.cc.
References count, e, and BMLoop::radial_next.
Referenced by similar_edge_select_exec().
Utility function, since enough times we have an edge and want to access 2 connected faces.
Definition at line 546 of file bmesh_query.cc.
References e, BMLoop::f, and BMLoop::radial_next.
Referenced by BM_edge_calc_rotate(), BM_edge_rotate(), BM_edge_rotate_check(), bm_face_split_by_edges_island_connect(), bmo_dissolve_edges_exec(), bmo_join_triangles_exec(), bmo_rotate_edges_exec(), bmo_vert_calc_edge_angle_blended(), edbm_edge_rotate_selected_exec(), and hull_merge_triangles().
Returns an edge sharing the same vertices as this one. This isn't an invalid state but tools should clean up these cases before returning the mesh to the user.
Definition at line 1592 of file bmesh_query.cc.
References BM_vert_in_edge(), bmesh_disk_edge_next(), e, UNLIKELY, and v.
Referenced by bm_decim_edge_collapse(), BM_face_split_edgenet_connect_islands(), BM_mesh_edgesplit(), and bmo_spin_exec().
Only BMEdge.l access us needed, however when we want the first visible loop, a utility function is needed.
Definition at line 1609 of file bmesh_query.cc.
References BM_elem_flag_test, BM_ELEM_HIDDEN, e, BMLoop::f, and BMLoop::radial_next.
Returns whether or not a given edge is part of a given face.
Definition at line 428 of file bmesh_query.cc.
References e, BMLoop::f, and BMLoop::radial_next.
Referenced by BM_edge_share_face_check(), BM_edge_share_quad_check(), BM_face_share_edge_check(), BM_face_share_edge_count(), BM_face_split_edgenet(), bm_face_split_edgenet_partial_connect(), bm_isect_tri_tri(), bm_loop_customdata_merge(), bm_ray_cast_cb_elem_not_in_face_check(), bm_vert_pair_best_face_get(), bmesh_kernel_join_face_kill_edge(), edge_ray_cast(), edgering_find_order(), face_edges_add(), knife_calculate_snap_ref_edges(), knife_make_face_cuts(), knife_snap_angle_relative(), blender::bke::pbvh::merge_flap_edge_data(), blender::draw::mesh_render_data_edge_flag(), multires_unsubdivide_extract_single_grid_from_face_edge(), blender::bke::pbvh::pbvh_bmesh_collapse_edge(), and test_tagged_and_notface().
| bool BM_edge_is_all_face_flag_test | ( | const BMEdge * | e, |
| const char | hflag, | ||
| const bool | respect_hide ) |
Definition at line 1962 of file bmesh_query.cc.
References BM_elem_flag_test, BM_ELEM_HIDDEN, e, BMLoop::f, and BMLoop::radial_next.
Referenced by bmw_edge_is_wire(), and EDBM_selectmode_convert().
| bool BM_edge_is_any_face_flag_test | ( | const BMEdge * | e, |
| const char | hflag ) |
Definition at line 1980 of file bmesh_query.cc.
References BM_elem_flag_test, e, BMLoop::f, and BMLoop::radial_next.
Referenced by BM_mesh_uvselect_flush_post_subdivide(), and edbm_select_linked_exec().
| bool BM_edge_is_any_face_len_test | ( | const BMEdge * | e, |
| const int | len ) |
Definition at line 2029 of file bmesh_query.cc.
References e, BMLoop::f, BMFace::len, len, and BMLoop::radial_next.
Referenced by EDBM_preselect_edgering_update_from_edge(), and ringsel_finish().
| bool BM_edge_is_any_vert_flag_test | ( | const BMEdge * | e, |
| const char | hflag ) |
Definition at line 1996 of file bmesh_query.cc.
References BM_elem_flag_test, and e.
Referenced by EDBM_selectmode_convert().
| bool BM_edge_is_contiguous_loop_cd | ( | const BMEdge * | e, |
| int | cd_loop_type, | ||
| int | cd_loop_offset ) |
Definition at line 883 of file bmesh_query.cc.
References BLI_assert, BM_ELEM_CD_GET_VOID_P, CustomData_data_equals(), e, BMLoop::next, BMLoop::radial_next, and BMLoop::v.
Referenced by bm_edge_is_contiguous_loop_cd_all(), bm_edge_is_contiguous_loop_cd_all(), and select_linked_delimit_test().
| bool BM_edge_is_convex | ( | const BMEdge * | e | ) |
Check if the edge is convex or concave (depends on face winding)
Definition at line 866 of file bmesh_query.cc.
References BM_edge_is_manifold(), BMVert::co, cross, cross_v3_v3v3(), dot_v3v3(), e, equals_v3v3(), BMLoop::f, BMLoop::next, BMFace::no, sub_v3_v3v3(), and BMLoop::v.
Referenced by BM_edge_calc_face_angle_signed_ex(), and bpy_bmedge_is_convex_get().
Utility function, since enough times we have an edge and want to access 2 connected loops.
Definition at line 561 of file bmesh_query.cc.
References e, and BMLoop::radial_next.
Referenced by bm_decim_triangulate_end(), bm_edge_collapse(), bm_face_split_by_concave(), BM_normals_loops_edges_tag(), bmo_dissolve_edges_exec(), bmo_dissolve_verts_exec(), contig_ldata_across_edge(), DRW_text_edit_mesh_measure_stats(), edbm_polybuild_dissolve_at_cursor_invoke(), edbm_ripsel_edge_mark_step(), edbm_ripsel_looptag_helper(), edbm_select_sharp_edges_exec(), edbm_tagged_loop_pairs_to_fill(), modify_mesh(), blender::bke::pbvh::pbvh_bmesh_edge_loops(), and blender::ed::mesh::set_sharpness_by_angle_exec().
Definition at line 1151 of file bmesh_query.cc.
References BM_edge_ordered_verts_ex(), and BMEdge::l.
Referenced by BM_edge_calc_rotate(), BM_edge_rotate_check_degenerate(), BM_face_create_ngon_verts(), and blender::ed::transform::getTransformOrientation_ex().
| void BM_edge_ordered_verts_ex | ( | const BMEdge * | edge, |
| BMVert ** | r_v1, | ||
| BMVert ** | r_v2, | ||
| const BMLoop * | edge_loop ) |
Returns the verts of an edge as used in a face if used in a face at all, otherwise just assign as used in the edge.
Useful to get a deterministic winding order when calling BM_face_create_ngon() on an arbitrary array of verts, though be sure to pick an edge which has a face.
Definition at line 1140 of file bmesh_query.cc.
References BLI_assert, BMLoop::e, BMLoop::next, and BMLoop::v.
Referenced by BM_edge_calc_face_tangent(), BM_edge_ordered_verts(), and bmo_inset_region_exec().
Given a edge and a loop (assumes the edge is manifold). returns the other faces loop, sharing the same vertex.
+-------------------+ | | | | |l_other <-- return | +-------------------+ <-- A manifold edge between 2 faces |l e <-- edge | |^ <-------- loop | | | +-------------------+
Definition at line 444 of file bmesh_query.cc.
References BLI_assert, BM_vert_in_edge(), BMLoop::e, e, l, BMLoop::next, BMLoop::radial_next, and BMLoop::v.
Referenced by bm_extrude_copy_face_loop_attributes(), bm_loop_customdata_merge(), BM_vert_step_fan_loop(), bmo_inset_region_exec(), and edbm_tagged_loop_pairs_do_fill_faces().
| BMFace * BM_edge_pair_share_face_by_len | ( | BMEdge * | e_a, |
| BMEdge * | e_b, | ||
| BMLoop ** | r_l_a, | ||
| BMLoop ** | r_l_b, | ||
| const bool | allow_adjacent ) |
Definition at line 200 of file bmesh_query.cc.
References BM_face_edge_share_loop(), BM_ITER_ELEM, BM_loop_is_adjacent(), BM_LOOPS_OF_EDGE, BMLoop::f, BMEdge::l, l_b, and BMFace::len.
Referenced by bm_vert_connect_select_history_edge_to_vert_path().
Test if e1 shares any faces with e2
Definition at line 1046 of file bmesh_query.cc.
References BM_edge_in_face(), BMEdge::l, and l.
Referenced by BM_disk_dissolve(), edbm_add_edge_face_exec__tricky_extend_sel(), and view3d_preselect_mesh_edgering_update_edges_from_edge().
Test if e1 shares any quad faces with e2
Definition at line 1064 of file bmesh_query.cc.
References BM_edge_in_face(), BMEdge::l, l, and BMFace::len.
Referenced by edge_step(), and view3d_preselect_mesh_edgering_update_edges_from_edge().
Return the shared vertex between the two edges or NULL
Definition at line 1089 of file bmesh_query.cc.
References BLI_assert, BM_vert_in_edge(), BMEdge::v1, and BMEdge::v2.
Referenced by bm_edge_collapse(), BM_verts_from_edges(), and edbm_tagged_loop_pairs_do_fill_faces().
Tests to see if e1 shares a vertex with e2
Definition at line 1084 of file bmesh_query.cc.
References BMEdge::v1, and BMEdge::v2.
Referenced by bm_edgexedge_isect_cb(), BM_mesh_decimate_collapse(), bmo_edgenet_prepare_exec(), and bmo_subdivide_edges_exec().
Return the Loop Shared by Edge and Vert.
Finds the loop used which uses v in face loop l
Definition at line 1101 of file bmesh_query.cc.
References BLI_assert, BM_vert_in_edge(), l, and v.
Referenced by edbm_rip_invoke__vert().
Definition at line 228 of file bmesh_query.cc.
References BM_face_calc_normal_subset(), dot_v3v3(), and l_b.
Referenced by BM_vert_pair_share_face_by_angle().
Return the Loop Shared by Face and Edge.
Finds the loop used which uses e in face loop l
Definition at line 1125 of file bmesh_query.cc.
References e, BMLoop::f, and BMLoop::radial_next.
Referenced by bev_ccw_test(), BM_edge_pair_share_face_by_len(), BM_edge_rotate(), BM_face_other_edge_loop(), bmesh_kernel_join_face_kill_edge(), ED_uvedit_active_edge_loop_get(), edbm_add_edge_face_exec__tricky_finalize_sel(), blender::draw::extract_edituv_data_iter_subdiv_bm(), fast_bevel_edge_order(), geometry_collide_offset(), and knife_add_single_cut__is_linehit_outside_face().
Given a set of vertices (varr), find out if there is a face with exactly those vertices (and only those vertices).
Definition at line 1623 of file bmesh_query.cc.
References BM_DISK_EDGE_NEXT, BMVert::e, e, BMLoop::f, BMEdge::l, BMFace::len, len, BMLoop::next, BMLoop::prev, BMLoop::radial_next, and BMLoop::v.
Referenced by BM_face_create(), bm_vert_dissolve_fan_test(), bmo_edgeloop_fill_exec(), bpy_bmfaceseq_get__method(), bpy_bmfaceseq_new(), bridge_loop_pair(), edbm_tagged_loop_pairs_do_fill_faces(), EDBM_verts_mirror_get_face(), blender::bke::pbvh::pbvh_bmesh_collapse_edge(), blender::bke::pbvh::pbvh_bmesh_face_create(), and remdoubles_createface().
Given a set of vertices and edges (varr, earr), find out if all those vertices are filled in by existing faces that only use those vertices.
This is for use in cases where creating a face is possible but would result in many overlapping faces.
An example of how this is used: when 2 triangles are selected that share an edge, pressing F-key would make a new overlapping quad (without a check like this)
earr and varr can be in any order, however they must form a closed loop.
Definition at line 1703 of file bmesh_query.cc.
References BM_EDGES_OF_VERT, BM_elem_flag_disable, BM_elem_flag_enable, BM_elem_flag_test, BM_ELEM_INTERNAL_TAG, BM_FACES_OF_EDGE, BM_ITER_ELEM, BM_VERTS_OF_FACE, e, i, len, and v.
Referenced by bm_edgenet_face_from_path(), and BM_face_exists_multi_edge().
| bool BM_face_exists_multi_edge | ( | BMEdge ** | earr, |
| int | len ) |
Definition at line 1812 of file bmesh_query.cc.
References BLI_array_alloca, BM_face_exists_multi(), BM_verts_from_edges(), BMESH_ASSERT, and len.
Given a set of vertices (varr), find out if all those vertices overlap an existing face.
Definition at line 1825 of file bmesh_query.cc.
References _FLAG_OVERLAP, BLI_assert, BLI_linklist_prepend_alloca, BM_ELEM_API_FLAG_DISABLE, BM_ELEM_API_FLAG_ENABLE, BM_ELEM_API_FLAG_TEST, BM_FACES_OF_VERT, BM_ITER_ELEM, BM_verts_in_face_count(), i, len, LinkNode::link, and LinkNode::next.
| bool BM_face_exists_overlap_subset | ( | BMVert ** | varr, |
| int | len ) |
Given a set of vertices (varr), find out if there is a face that uses vertices only from this list (that the face is a subset or made from the vertices given).
Definition at line 1863 of file bmesh_query.cc.
References _FLAG_OVERLAP, BLI_assert, BLI_linklist_prepend_alloca, BM_ELEM_API_FLAG_DISABLE, BM_ELEM_API_FLAG_ENABLE, BM_ELEM_API_FLAG_TEST, BM_FACE_FIRST_LOOP, BM_FACES_OF_VERT, BM_ITER_ELEM, i, BMFace::len, len, LinkNode::link, BMLoop::next, LinkNode::next, and BMLoop::v.
Referenced by bm_edgenet_path_check_overlap().
Check if the face has an exact duplicate (both winding directions).
Definition at line 1671 of file bmesh_query.cc.
References BM_FACE_FIRST_LOOP, BMLoop::e, BMLoop::f, l_b, BMFace::len, BMLoop::next, BMLoop::prev, BMLoop::radial_next, and BMLoop::v.
Referenced by bm_face_connect_verts(), BM_faces_join(), bmesh_kernel_join_edge_kill_vert(), and bmo_spin_exec().
Returns the loop of the longest edge in f.
Definition at line 1519 of file bmesh_query.cc.
References BM_FACE_FIRST_LOOP, BMVert::co, len_squared_v3v3(), BMLoop::next, and BMLoop::v.
Referenced by BM_face_calc_tangent_from_edge(), BM_face_calc_tangent_from_edge_pair(), BM_face_calc_tangent_pair_from_edge(), and skin_fix_hole_no_good_verts().
Returns the loop of the shortest edge in f.
Definition at line 1498 of file bmesh_query.cc.
References BM_FACE_FIRST_LOOP, BMVert::co, FLT_MAX, len_squared_v3v3(), BMLoop::next, and BMLoop::v.
Referenced by collapse_face_corners().
| bool BM_face_is_any_edge_flag_test | ( | const BMFace * | f, |
| const char | hflag ) |
Definition at line 2015 of file bmesh_query.cc.
References BM_elem_flag_test, BM_FACE_FIRST_LOOP, BMLoop::e, and BMLoop::next.
Referenced by EDBM_selectmode_convert().
| bool BM_face_is_any_vert_flag_test | ( | const BMFace * | f, |
| const char | hflag ) |
Definition at line 2001 of file bmesh_query.cc.
References BM_elem_flag_test, BM_FACE_FIRST_LOOP, BMLoop::next, and BMLoop::v.
Referenced by EDBM_selectmode_convert().
| bool BM_face_is_normal_valid | ( | const BMFace * | f | ) |
Use within asserts to check normals are valid.
Definition at line 2045 of file bmesh_query.cc.
References BM_face_calc_normal(), eps, len_squared_v3v3(), and BMFace::no.
Referenced by bm_face_bisect_verts(), BM_face_interp_from_face(), BM_face_point_inside_test(), BM_face_splits_check_legal(), BM_face_triangulate(), BM_face_uv_point_inside_test(), bm_interp_face_store(), BM_vert_interp_from_face(), bmesh_calc_tessellation_for_face_impl(), hull_merge_triangles(), and recalc_face_normals_find_index().
Other Loop in Face Sharing an Edge.
Finds the other loop that shares v with e loop in f.
+----------+
| |
| f |
| |
+----------+ <-- return the face loop of this vertex.
v --> e
^ ^ <------- These vert args define direction
in the face to check.
The faces loop direction is ignored.
Definition at line 32 of file bmesh_query.cc.
References BLI_assert, BM_face_edge_share_loop(), BM_loop_other_edge_loop(), e, l, and v.
Other Loop in Face Sharing a Vertex.
Finds the other loop in a face.
This function returns a loop in f that shares an edge with v The direction is defined by v_prev, where the return value is the loop of what would be 'v_next'
+----------+ <-- return the face loop of this vertex.
| |
| f |
| |
+----------+
v_prev --> v
^^^^^^ ^ <-- These vert args define direction
in the face to check.
The faces loop direction is ignored.
Definition at line 45 of file bmesh_query.cc.
References BLI_assert, BM_edge_exists(), BM_face_vert_share_loop(), BMLoop::next, BMLoop::prev, BMLoop::v, and v.
Referenced by BM_edge_calc_rotate(), BM_edge_rotate_check(), BM_edge_rotate_check_degenerate(), BM_loop_other_vert_loop(), bmw_EdgeLoopWalker_step(), and edbm_rip_edge_side_measure().
Returns true if the faces share an edge
Definition at line 994 of file bmesh_query.cc.
References BM_edge_in_face(), BM_FACE_FIRST_LOOP, BMLoop::e, and BMLoop::next.
Referenced by BM_face_share_face_check(), BM_face_share_face_count(), bm_isect_tri_tri(), and face_step().
Counts the number of edges two faces share (if any)
Definition at line 978 of file bmesh_query.cc.
References BM_edge_in_face(), BM_FACE_FIRST_LOOP, count, BMLoop::e, and BMLoop::next.
Referenced by bmesh_kernel_join_face_kill_edge().
same as BM_face_share_face_count but returns a bool
Definition at line 961 of file bmesh_query.cc.
References BM_EDGES_OF_FACE, BM_face_share_edge_check(), BM_FACES_OF_EDGE, BM_ITER_ELEM, and e.
Referenced by hull_merge_triangles().
Returns the number of faces that are adjacent to both f1 and f2,
Definition at line 943 of file bmesh_query.cc.
References BM_EDGES_OF_FACE, BM_face_share_edge_check(), BM_FACES_OF_EDGE, BM_ITER_ELEM, count, and e.
Returns true if the faces share a vert.
Definition at line 1025 of file bmesh_query.cc.
References BM_FACE_FIRST_LOOP, BM_vert_in_face(), BMLoop::next, and BMLoop::v.
Counts the number of verts two faces share (if any).
Definition at line 1009 of file bmesh_query.cc.
References BM_FACE_FIRST_LOOP, BM_vert_in_face(), count, BMLoop::next, and BMLoop::v.
Referenced by bm_face_split_by_edges_island_connect().
Return the Loop Shared by Face and Vertex.
Finds the loop used which uses v in face loop l
Definition at line 1110 of file bmesh_query.cc.
References BM_FACE_FIRST_LOOP, BMLoop::next, BMLoop::v, and v.
Referenced by BM_disk_dissolve(), BM_edge_rotate(), bm_face_bisect_verts(), bm_face_connect_verts(), BM_face_other_vert_loop(), bm_loop_normal_mark_indiv(), BM_vert_collapse_faces(), BM_vert_pair_share_face_by_angle(), BM_vert_pair_share_face_by_len(), BM_vert_pair_shared_face_cb(), bpy_bm_utils_face_split(), bpy_bm_utils_face_vert_separate(), ED_uvedit_active_vert_loop_get(), edbm_add_edge_face_exec__tricky_finalize_sel(), edbm_set_normals_from_faces_exec(), knife_add_single_cut__is_linehit_outside_face(), knife_verts_edge_in_face(), offset_meet_lines_percent_or_absolute(), remdoubles_splitface(), update_uv_vert_map(), and uv_copy_mirrored_faces().
Calculates the angle between the previous and next loops (angle at this loops face corner).
Definition at line 1202 of file bmesh_query.cc.
References angle_v3v3v3(), and l.
Referenced by BM_mesh_wireframe(), BM_vert_calc_shell_factor(), BM_vert_calc_shell_factor_ex(), bpy_bmloop_calc_angle(), and edbm_average_normals_exec().
BM_loop_calc_face_direction.
Calculate the direction a loop is pointing.
| l | The loop to calculate the direction at |
| r_dir | Resulting direction |
Definition at line 1294 of file bmesh_query.cc.
References add_v3_v3v3(), l, normalize_v3(), and sub_v3_v3v3().
Referenced by blender::ed::transform::isect_face_dst().
BM_loop_calc_face_normal.
Calculate the normal at this loop corner or fall back to the face normal on straight lines.
| l | The loop to calculate the normal at |
| r_normal | Resulting normal |
Definition at line 1280 of file bmesh_query.cc.
References copy_v3_v3(), cross_v3_v3v3(), l, len, normalize_v3(), sub_v3_v3v3(), UNLIKELY, and v2.
Referenced by bpy_bmloop_calc_normal().
BM_loop_calc_face_normal_safe_ex with predefined sane epsilon.
Since this doesn't scale based on triangle size, fixed value works well.
Definition at line 1266 of file bmesh_query.cc.
References BM_loop_calc_face_normal_safe_ex(), and l.
Referenced by blender::draw::statvis_calc_distort().
BM_loop_calc_face_normal.
Calculate the normal at this loop corner or fall back to the face normal on straight lines.
| l | The loop to calculate the normal at. |
| epsilon_sq | Value to avoid numeric errors (1e-5f works well). |
| r_normal | Resulting normal. |
Definition at line 1207 of file bmesh_query.cc.
References copy_v3_v3(), cross_v3_v3v3(), is_zero_v3(), l, len_squared_v3(), mul_v3_v3fl(), normalize_v3(), sub_v3_v3(), sub_v3_v3v3(), and v2.
Referenced by BM_loop_calc_face_normal_safe().
| float BM_loop_calc_face_normal_safe_vcos | ( | const BMLoop * | l, |
| const float | normal_fallback[3], | ||
| float const (*) | vertexCos[3], | ||
| float | r_normal[3] ) |
Definition at line 1271 of file bmesh_query.cc.
References BM_loop_calc_face_normal_safe_vcos_ex(), and l.
Referenced by blender::draw::statvis_calc_distort().
| float BM_loop_calc_face_normal_safe_vcos_ex | ( | const BMLoop * | l, |
| const float | normal_fallback[3], | ||
| float const (*) | vertexCos[3], | ||
| float | epsilon_sq, | ||
| float | r_normal[3] ) |
A version of BM_loop_calc_face_normal_safe_ex which takes vertex coordinates.
Definition at line 1236 of file bmesh_query.cc.
References BM_elem_index_get, copy_v3_v3(), cross_v3_v3v3(), i, is_zero_v3(), l, len_squared_v3(), mul_v3_v3fl(), normalize_v3(), sub_v3_v3(), sub_v3_v3v3(), and v2.
Referenced by BM_loop_calc_face_normal_safe_vcos().
BM_loop_calc_face_tangent.
Calculate the tangent at this loop corner or fall back to the face normal on straight lines. This vector always points inward into the face.
| l | The loop to calculate the tangent at |
| r_tangent | Resulting tangent |
Definition at line 1309 of file bmesh_query.cc.
References add_v3_v3v3(), compare_v3v3(), cross_v3_v3v3(), dot_v3v3(), l, negate_v3(), nor, normalize_v3(), sub_v3_v3v3(), and UNLIKELY.
Referenced by BM_mesh_wireframe(), bpy_bmloop_calc_tangent(), and edbm_calc_loop_co().
Definition at line 1173 of file bmesh_query.cc.
References BLI_assert, BMVert::co, ELEM, l, len_squared_v3v3(), BMLoop::next, UNLIKELY, and BMLoop::v.
Referenced by blender::ed::transform::mesh_customdatacorrect_init_vert().
Definition at line 1156 of file bmesh_query.cc.
References BLI_assert, BMVert::co, ELEM, l, len_squared_v3v3(), BMLoop::prev, UNLIKELY, and BMLoop::v.
Referenced by blender::ed::transform::mesh_customdatacorrect_init_vert().
| bool BM_loop_is_convex | ( | const BMLoop * | l | ) |
Check if the loop is convex or concave (depends on face normal)
Definition at line 1190 of file bmesh_query.cc.
References cross_v3_v3v3(), dot_v3v3(), l, and sub_v3_v3v3().
Referenced by bm_face_convex_tag_verts(), and bpy_bmloop_is_convex_get().
See BM_face_other_edge_loop This is the same functionality to be used when the edges loop is already known.
Definition at line 39 of file bmesh_query.cc.
References BLI_assert, BM_vert_in_edge(), l, and v.
Referenced by BM_face_other_edge_loop(), bmo_vert_touches_unselected_face(), bmw_EdgeLoopWalker_step(), bmw_IslandboundWalker_step(), bmw_NonManifoldLoop_find_next_around_vertex(), edbm_rip_invoke__edge(), and edgering_find_order().
Other Loop in Face Sharing a Vert.
Finds the other loop that shares v with e loop in f.
+----------+ <-- return the face loop of this vertex.
| |
| |
| |
+----------+ <-- This vertex defines the direction.
l v
^ <------- This loop defines both the face to search
and the edge, in combination with 'v'
The faces loop direction is ignored.
Definition at line 67 of file bmesh_query.cc.
References BLI_assert, BM_edge_other_vert(), BM_face_other_vert_loop(), e, l, and v.
Referenced by BM_vert_other_disk_edge(), and bmo_inset_region_exec().
Return the other loop that uses this edge.
In this case the loop defines the vertex, the edge passed in defines the direction to step.
+----------+ <-- Return the face-loop of this vertex.
| |
| e | <-- This edge defines the direction.
| |
+----------+ <-- This loop defines the face and vertex..
l
Definition at line 92 of file bmesh_query.cc.
References BLI_assert, BM_vert_in_edge(), e, and l.
Referenced by BM_edge_uv_share_vert_check().
Check if a point is inside the edge defined by a loop (within the plane defined by the loops edge & face normal).
Definition at line 246 of file bmesh_query.cc.
References cross_v3_v3v3(), dist_signed_squared_to_plane_v3(), dot_v3v3(), l, and sub_v3_v3v3().
Referenced by knife_add_single_cut__is_linehit_outside_face().
Check if a point is inside the corner defined by a loop (within the 2 planes defined by the loops corner & face normal).
Definition at line 240 of file bmesh_query.cc.
References dist_signed_squared_to_corner_v3v3v3(), and l.
Referenced by knife_add_single_cut__is_linehit_outside_face().
|
static |
Definition at line 813 of file bmesh_query.cc.
References BM_DISK_EDGE_NEXT, BM_ELEM_API_FLAG_DISABLE, count, EDGE_VISIT, BMEdge::l, l, LOOP_VISIT, BMLoop::radial_next, and BMLoop::v.
Referenced by BM_loop_region_loops_count_at_most().
Definition at line 775 of file bmesh_query.cc.
References BLI_assert, BM_ELEM_API_FLAG_ENABLE, BM_ELEM_API_FLAG_TEST, bm_loop_region_count__recursive(), count, BMLoop::e, e, EDGE_VISIT, LOOP_VISIT, BMLoop::next, BMLoop::prev, BMLoop::radial_next, BMLoop::v, and v.
Referenced by bm_loop_region_count__recursive(), and BM_loop_region_loops_count_at_most().
| int BM_loop_region_loops_count | ( | BMLoop * | l | ) |
Definition at line 850 of file bmesh_query.cc.
References BM_loop_region_loops_count_at_most(), and l.
| int BM_loop_region_loops_count_at_most | ( | BMLoop * | l, |
| int * | r_loop_total ) |
The number of loops connected to this loop (not including disconnected regions).
Definition at line 837 of file bmesh_query.cc.
References bm_loop_region_count__clear(), bm_loop_region_count__recursive(), count, and l.
Referenced by BM_loop_region_loops_count(), and BM_vert_is_manifold_region().
Returns true when 2 loops share an edge (are adjacent in the face-fan)
Definition at line 1040 of file bmesh_query.cc.
References BLI_assert, BMLoop::e, ELEM, l_b, BMLoop::prev, and BMLoop::v.
Referenced by facetag_add_adjacent(), and facetag_add_adjacent_uv().
| int BM_mesh_calc_edge_groups | ( | BMesh * | bm, |
| int * | r_groups_array, | ||
| int(**) | r_group_index[2], | ||
| BMVertFilterFunc | filter_fn, | ||
| void * | user_data, | ||
| const char | hflag_test ) |
Definition at line 2263 of file bmesh_query.cc.
References BLI_assert, bm, BM_EDGE, BM_EDGES_OF_MESH, BM_EDGES_OF_VERT, BM_elem_flag_disable, BM_elem_flag_enable, BM_elem_flag_test, BM_elem_index_get, BM_elem_index_set, BM_ELEM_TAG, BM_ITER_ELEM, BM_ITER_MESH_INDEX, BM_iter_new, BM_VERTS_OF_EDGE, e, i, MEM_freeN(), MEM_malloc_arrayN(), MEM_mallocN(), MEM_reallocN, STACK_DECLARE, STACK_INIT, STACK_POP, STACK_PUSH, STACK_SIZE, UNUSED_VARS_NDEBUG, and v.
Referenced by blender::ed::transform::transform_convert_mesh_islands_calc().
| int BM_mesh_calc_edge_groups_as_arrays | ( | BMesh * | bm, |
| BMVert ** | verts, | ||
| BMEdge ** | edges, | ||
| BMFace ** | faces, | ||
| int(**) | r_groups[3] ) |
Definition at line 2388 of file bmesh_query.cc.
References bm, BM_DISK_EDGE_NEXT, BM_EDGE, BM_edge_other_vert(), BM_elem_flag_enable, BM_elem_flag_test, BM_ELEM_TAG, BM_FACE, BM_ITER_MESH, BM_mesh_elem_hflag_disable_all(), BM_VERT, BM_VERTS_OF_MESH, BMVert::e, BMLoop::f, faces, BMEdge::l, MEM_freeN(), MEM_malloc_arrayN(), MEM_reallocN, BMLoop::radial_next, STACK_DECLARE, STACK_INIT, STACK_POP, STACK_PUSH, STACK_PUSH_RET, STACK_SIZE, and verts.
Referenced by mesh_separate_loose().
| int BM_mesh_calc_face_groups | ( | BMesh * | bm, |
| int * | r_groups_array, | ||
| int(**) | r_group_index[2], | ||
| BMLoopFilterFunc | filter_fn, | ||
| BMLoopPairFilterFunc | filter_pair_fn, | ||
| void * | user_data, | ||
| const char | hflag_test, | ||
| const char | htype_step ) |
Definition at line 2106 of file bmesh_query.cc.
References BLI_assert, bm, BM_EDGE, BM_elem_flag_disable, BM_elem_flag_enable, BM_elem_flag_test, BM_elem_index_get, BM_elem_index_set, BM_ELEM_TAG, BM_FACE, BM_FACE_FIRST_LOOP, BM_FACES_OF_MESH, BM_ITER_ELEM, BM_ITER_MESH_INDEX, BM_iter_new, BM_LOOPS_OF_LOOP, BM_VERT, BMLoop::f, i, MEM_freeN(), MEM_malloc_arrayN(), MEM_mallocN(), MEM_reallocN, BMLoop::next, BMLoop::radial_next, STACK_DECLARE, STACK_INIT, STACK_POP, STACK_PUSH, STACK_SIZE, and UNUSED_VARS_NDEBUG.
Referenced by bm_mesh_calc_uv_islands(), BM_mesh_intersect(), bmo_recalc_face_normals_exec(), EDBM_select_interior_faces(), edbm_select_similar_region_exec(), and blender::ed::transform::transform_convert_mesh_islands_calc().
| double BM_mesh_calc_volume | ( | BMesh * | bm, |
| bool | is_signed ) |
Definition at line 2088 of file bmesh_query.cc.
References bm, BM_FACES_OF_MESH, BM_ITER_MESH, bm_mesh_calc_volume_face(), and fabs().
Referenced by bpy_bmesh_calc_volume(), and validate_solution().
|
static |
Use to accumulate volume calculation for faces with consistent winding.
Use double precision since this is prone to float precision error, see #73295.
Definition at line 2059 of file bmesh_query.cc.
References BLI_array_alloca, BM_face_calc_tessellation(), BMVert::co, copy_v3db_v3fl(), cross, cross_v3_v3v3_db(), dot_v3v3_db(), BMFace::len, and BMLoop::v.
Referenced by BM_mesh_calc_volume().
Definition at line 1426 of file bmesh_query.cc.
References BM_vert_calc_edge_angle_ex(), DEG2RADF, and v.
Referenced by bm_vert_edge_face_angle().
BMESH VERT/EDGE ANGLE.
Calculates the angle a verts 2 edges.
Definition at line 1407 of file bmesh_query.cc.
References angle_v3v3v3(), BM_edge_other_vert(), bmesh_disk_edge_next(), BMVert::co, float, M_PI, v, and v2.
Referenced by BM_vert_calc_edge_angle(), and bpy_bmvert_calc_edge_angle().
Definition at line 1478 of file bmesh_query.cc.
References BM_edge_calc_length(), BM_edge_other_vert(), BM_EDGES_OF_VERT, BM_elem_flag_test, BM_ELEM_TAG, BM_ITER_ELEM_INDEX, e, float, length(), and v.
Referenced by BM_mesh_wireframe().
Definition at line 1431 of file bmesh_query.cc.
References BM_ITER_ELEM, BM_loop_calc_face_angle(), BM_LOOPS_OF_VERT, l, shell_v3v3_normalized_to_dist(), and v.
Referenced by BM_vert_calc_shell_factor_ex(), bmo_inset_region_exec(), and bpy_bmvert_calc_shell_factor().
Definition at line 1449 of file bmesh_query.cc.
References BM_elem_flag_test, BM_ITER_ELEM, BM_loop_calc_face_angle(), BM_LOOPS_OF_VERT, BM_vert_calc_shell_factor(), l, shell_v3v3_normalized_to_dist(), and v.
Referenced by blender::ed::transform::VertsToTransData().
| int BM_vert_edge_count | ( | const BMVert * | v | ) |
Returns the number of edges around this vertex.
Definition at line 615 of file bmesh_query.cc.
References bmesh_disk_count(), and v.
Referenced by BKE_mesh_remesh_voxel_fix_poles(), and similar_vert_select_exec().
| int BM_vert_edge_count_at_most | ( | const BMVert * | v, |
| const int | count_max ) |
Definition at line 620 of file bmesh_query.cc.
References bmesh_disk_count_at_most(), and v.
Referenced by BM_vert_dissolve(), and edbm_select_by_pole_count_exec().
| int BM_vert_edge_count_nonwire | ( | const BMVert * | v | ) |
Definition at line 625 of file bmesh_query.cc.
References BM_EDGES_OF_VERT, BM_ITER_ELEM, count, BMEdge::l, and v.
Referenced by bmw_EdgeLoopWalker_begin(), and bmw_EdgeLoopWalker_step().
Access a verts 2 connected edges.
Definition at line 598 of file bmesh_query.cc.
References BM_DISK_EDGE_NEXT, and v.
Referenced by bm_vert_collapse_edge_and_merge(), bm_vert_collapse_is_degenerate(), bmo_dissolve_edges_exec(), bmo_vert_calc_edge_angle_blended(), and blender::ed::transform::getTransformOrientation_ex().
| bool BM_vert_face_check | ( | const BMVert * | v | ) |
Return true if the vertex is connected to any faces.
same as BM_vert_face_count(v) != 0 or BM_vert_find_first_loop(v) == NULL.
Definition at line 682 of file bmesh_query.cc.
References bmesh_disk_edge_next(), BMEdge::l, and v.
Referenced by bevel_vert_two_edges(), and blender::bke::pbvh::pbvh_bmesh_collapse_edge().
| int BM_vert_face_count | ( | const BMVert * | v | ) |
Returns the number of faces around this vert length matches BM_LOOPS_OF_VERT iterator
Definition at line 672 of file bmesh_query.cc.
References bmesh_disk_facevert_count(), and v.
Referenced by bmo_pointmerge_facedata_exec(), bmw_EdgeLoopWalker_begin(), and similar_vert_select_exec().
| int BM_vert_face_count_at_most | ( | const BMVert * | v, |
| int | count_max ) |
Definition at line 677 of file bmesh_query.cc.
References bmesh_disk_facevert_count_at_most(), and v.
Referenced by blender::bke::pbvh::find_outer_flap_vert().
Get the first loop of a vert. Uses the same initialization code for the first loop of the iterator API
Definition at line 305 of file bmesh_query.cc.
References bmesh_disk_faceloop_find_first(), and v.
Referenced by BM_mesh_partial_create_from_verts_group_multi(), BM_mesh_partial_create_from_verts_group_single(), BM_vert_is_manifold_region(), edbm_rip_invoke__vert(), blender::draw::extract_points_bm(), and blender::bke::pbvh::try_merge_flap_edge_data_before_dissolve().
A version of BM_vert_find_first_loop that ignores hidden loops.
Definition at line 309 of file bmesh_query.cc.
References bmesh_disk_faceloop_find_first_visible(), and v.
Returns true if the vertex is used in a given face.
Definition at line 314 of file bmesh_query.cc.
References BMFace::l_first, BMLoop::next, BMLoop::v, and v.
Referenced by BM_face_share_vert_check(), BM_face_share_vert_count(), bm_ray_cast_cb_elem_not_in_face_check(), bm_vert_in_faces_radial(), BM_vert_pair_share_face_check(), BM_vert_pair_share_face_check_cb(), bmo_subdivide_edges_exec(), collapse_face_corners(), edbm_face_split_by_edges_exec(), multires_unsubdivide_extract_grids(), and blender::bke::pbvh::vert_in_face_adjacent_to_edge().
| bool BM_vert_is_all_edge_flag_test | ( | const BMVert * | v, |
| const char | hflag, | ||
| const bool | respect_hide ) |
Definition at line 1926 of file bmesh_query.cc.
References BM_EDGES_OF_VERT, BM_elem_flag_test, BM_ELEM_HIDDEN, BM_ITER_ELEM, and v.
Referenced by EDBM_selectmode_convert().
| bool BM_vert_is_all_face_flag_test | ( | const BMVert * | v, |
| const char | hflag, | ||
| const bool | respect_hide ) |
Definition at line 1944 of file bmesh_query.cc.
References BM_elem_flag_test, BM_ELEM_HIDDEN, BM_FACES_OF_VERT, BM_ITER_ELEM, and v.
Referenced by EDBM_selectmode_convert().
| bool BM_vert_is_boundary | ( | const BMVert * | v | ) |
Definition at line 926 of file bmesh_query.cc.
References BM_edge_is_boundary(), bmesh_disk_edge_next(), and v.
Referenced by blender::ed::sculpt_paint::expand::boundary_from_enabled(), bpy_bmvert_is_boundary_get(), blender::ed::sculpt_paint::smooth::calc_relaxed_translations_bmesh(), geometry_extract_apply(), gizmo_preselect_elem_test_select(), is_vertex_pole(), is_vertex_pole_three(), blender::ed::transform::mesh_vert_is_inner(), unsubdivide_is_center_vertex_tag_valid(), blender::ed::sculpt_paint::boundary::vert_is_boundary(), and blender::ed::sculpt_paint::vert_neighbors_get_interior_bmesh().
| bool BM_vert_is_edge_pair | ( | const BMVert * | v | ) |
Fast alternative to (BM_vert_edge_count(v) == 2).
Definition at line 576 of file bmesh_query.cc.
References BM_DISK_EDGE_NEXT, e, and v.
Referenced by bm_face_split(), bm_loop_collapse_is_degenerate(), BM_mesh_decimate_dissolve_ex(), BM_mesh_intersect(), bm_vert_other_edge(), bmo_dissolve_edges_exec(), bmo_dissolve_faces_exec(), bmo_dissolve_verts_exec(), bmo_extrude_face_region_exec(), bmo_find_end_of_chain(), bmo_offset_edgeloops_exec(), edbm_polybuild_delete_at_cursor_invoke(), edbm_polybuild_dissolve_at_cursor_invoke(), and blender::ed::transform::mesh_vert_is_inner().
| bool BM_vert_is_edge_pair_manifold | ( | const BMVert * | v | ) |
Fast alternative to (BM_vert_edge_count(v) == 2) that checks both edges connect to the same faces.
Definition at line 586 of file bmesh_query.cc.
References BM_DISK_EDGE_NEXT, BM_edge_is_manifold(), e, and v.
Referenced by bm_loop_pair_ends(), bm_loop_region_test_chain(), bm_vert_pair_ends(), bm_vert_region_test_chain(), mesh_calc_path_region_elem(), and mesh_calc_path_region_elem().
| bool BM_vert_is_manifold | ( | const BMVert * | v | ) |
A vertex is non-manifold if it meets the following conditions: 1: Loose - (has no edges/faces incident upon it). 2: Joins two distinct regions - (two pyramids joined at the tip). 3: Is part of an edge with more than 2 faces. 4: Is part of a wire edge.
Definition at line 713 of file bmesh_query.cc.
References BLI_assert, BM_edge_is_boundary(), BM_vert_step_fan_loop(), bmesh_disk_edge_next(), BMLoop::e, BMEdge::l, BMLoop::next, BMLoop::radial_next, BMLoop::v, and v.
Referenced by BM_disk_dissolve(), BM_vert_dissolve(), bpy_bmvert_is_manifold_get(), calc_solidify_normals(), edbm_select_by_pole_count_exec(), and edbm_select_non_manifold_exec().
| bool BM_vert_is_manifold_region | ( | const BMVert * | v | ) |
A version of BM_vert_is_manifold which only checks if we're connected to multiple isolated regions.
Definition at line 855 of file bmesh_query.cc.
References BM_loop_region_loops_count_at_most(), BM_vert_find_first_loop(), count, and v.
Referenced by edbm_rip_invoke__vert().
| bool BM_vert_is_wire | ( | const BMVert * | v | ) |
Tests whether or not the vertex is part of a wire edge. (ie: has no faces attached to it)
Definition at line 696 of file bmesh_query.cc.
References bmesh_disk_edge_next(), BMEdge::l, and v.
Referenced by bm_vert_connect_select_history(), bpy_bmvert_is_wire_get(), edbm_polybuild_delete_at_cursor_invoke(), edbm_rip_invoke__vert(), and unsubdivide_is_all_quads().
The function takes a vertex at the center of a fan and returns the opposite edge in the fan. All edges in the fan must be manifold, otherwise return NULL.
Definition at line 490 of file bmesh_query.cc.
References BLI_assert, BM_edge_is_manifold(), BM_loop_other_vert_loop(), BM_vert_in_edge(), BMLoop::e, i, BMEdge::l, BMLoop::prev, BMLoop::radial_next, and v.
Referenced by edbm_rip_invoke__edge().
| BMFace * BM_vert_pair_share_face_by_angle | ( | BMVert * | v_a, |
| BMVert * | v_b, | ||
| BMLoop ** | r_l_a, | ||
| BMLoop ** | r_l_b, | ||
| bool | allow_adjacent ) |
Given 2 verts, find a face they share that has the lowest angle across these verts and give back both loops.
This can be better than BM_vert_pair_share_face_by_len because concave splits are ranked lowest.
Definition at line 259 of file bmesh_query.cc.
References bm_face_calc_split_dot(), BM_face_vert_share_loop(), BM_ITER_ELEM, BM_loop_is_adjacent(), BM_LOOPS_OF_VERT, dot(), BMVert::e, BMLoop::f, and l_b.
Referenced by BM_face_splits_check_optimal().
| BMFace * BM_vert_pair_share_face_by_len | ( | BMVert * | v_a, |
| BMVert * | v_b, | ||
| BMLoop ** | r_l_a, | ||
| BMLoop ** | r_l_b, | ||
| bool | allow_adjacent ) |
Given 2 verts, find the smallest face they share and give back both loops.
Definition at line 172 of file bmesh_query.cc.
References BM_face_vert_share_loop(), BM_ITER_ELEM, BM_loop_is_adjacent(), BM_LOOPS_OF_VERT, BMVert::e, BMLoop::f, l_b, and BMFace::len.
Referenced by connect_smallest_face().
Check if verts share a face.
Definition at line 106 of file bmesh_query.cc.
References BM_FACES_OF_VERT, BM_ITER_ELEM, BM_vert_in_face(), and BMVert::e.
Referenced by BM_mesh_intersect(), BM_mesh_intersect_edges(), BM_vert_splice(), and bpy_bm_utils_vert_splice().
| bool BM_vert_pair_share_face_check_cb | ( | BMVert * | v_a, |
| BMVert * | v_b, | ||
| bool(* | test_fn )(BMFace *, void *user_data), | ||
| void * | user_data ) |
Definition at line 122 of file bmesh_query.cc.
References BM_FACES_OF_VERT, BM_ITER_ELEM, BM_vert_in_face(), and BMVert::e.
Referenced by edbm_connect_vert_pair().
| BMFace * BM_vert_pair_shared_face_cb | ( | BMVert * | v_a, |
| BMVert * | v_b, | ||
| const bool | allow_adjacent, | ||
| bool(* | callback )(BMFace *, BMLoop *, BMLoop *, void *userdata), | ||
| void * | user_data, | ||
| BMLoop ** | r_l_a, | ||
| BMLoop ** | r_l_b ) |
Definition at line 143 of file bmesh_query.cc.
References BM_face_vert_share_loop(), BM_ITER_ELEM, BM_loop_is_adjacent(), BM_LOOPS_OF_VERT, BMVert::e, BMLoop::f, and l_b.
Referenced by bm_vert_pair_best_face_get().
Utility function to step around a fan of loops, using an edge to mark the previous side.
Definition at line 469 of file bmesh_query.cc.
References BLI_assert, BM_edge_is_manifold(), BM_edge_other_loop(), and l.
Referenced by bevel_harden_normals(), bm_edge_collapse_loop_customdata(), BM_loop_check_cyclic_smooth_fan(), bm_mesh_loops_calc_normals_for_loop(), BM_vert_is_manifold(), edbm_average_normals_exec(), and normals_split().
Return true if all verts are in the face.
Definition at line 378 of file bmesh_query.cc.
References _FLAG_OVERLAP, BM_ELEM_API_FLAG_DISABLE, BM_ELEM_API_FLAG_ENABLE, BM_ELEM_API_FLAG_TEST, i, BMFace::l_first, BMFace::len, len, BMLoop::next, and BMLoop::v.
Compares the number of vertices in an array that appear in a given face
Definition at line 338 of file bmesh_query.cc.
References _FLAG_OVERLAP, BM_ELEM_API_FLAG_DISABLE, BM_ELEM_API_FLAG_ENABLE, BM_ELEM_API_FLAG_TEST, count, i, BMFace::l_first, len, BMLoop::next, and BMLoop::v.
Referenced by BM_face_exists_overlap().
Definition at line 2473 of file bmesh_query.cc.
References BLI_assert, sqrtf, SUBD_FALLOFF_INVSQUARE, SUBD_FALLOFF_LIN, SUBD_FALLOFF_ROOT, SUBD_FALLOFF_SHARP, SUBD_FALLOFF_SMOOTH, and SUBD_FALLOFF_SPHERE.
Referenced by alter_co(), and bmo_subdivide_edgering_exec().