diff options
author | Campbell Barton <ideasman42@gmail.com> | 2019-02-26 08:03:21 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2019-02-26 08:03:21 +0300 |
commit | 58a394073fcd2cf009724514b483aa36b554c3cd (patch) | |
tree | d596057d157b3b831ee43425ad8bc535f43fca61 /source/blender/bmesh/intern/bmesh_structure.c | |
parent | 2986923f8c62ef78b783991ff5fbf9e8cadb209c (diff) |
BMesh: utility functions for visible element access
Needed for drawing code which skips hidden elements.
Diffstat (limited to 'source/blender/bmesh/intern/bmesh_structure.c')
-rw-r--r-- | source/blender/bmesh/intern/bmesh_structure.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/source/blender/bmesh/intern/bmesh_structure.c b/source/blender/bmesh/intern/bmesh_structure.c index 420e3c511cf..e4bad715b29 100644 --- a/source/blender/bmesh/intern/bmesh_structure.c +++ b/source/blender/bmesh/intern/bmesh_structure.c @@ -347,6 +347,28 @@ BMLoop *bmesh_disk_faceloop_find_first(const BMEdge *e, const BMVert *v) return NULL; } +/** + * A version of #bmesh_disk_faceloop_find_first that ignores hidden faces. + */ +BMLoop *bmesh_disk_faceloop_find_first_visible(const BMEdge *e, const BMVert *v) +{ + const BMEdge *e_iter = e; + do { + if (!BM_elem_flag_test(e_iter, BM_ELEM_HIDDEN)) { + if (e_iter->l != NULL) { + BMLoop *l_iter, *l_first; + l_iter = l_first = e_iter->l; + do { + if (!BM_elem_flag_test(l_iter->f, BM_ELEM_HIDDEN)) { + return (l_iter->v == v) ? l_iter : l_iter->next; + } + } while ((l_iter = l_iter->radial_next) != l_first); + } + } + } while ((e_iter = bmesh_disk_edge_next(e_iter, v)) != e); + return NULL; +} + BMEdge *bmesh_disk_faceedge_find_next(const BMEdge *e, const BMVert *v) { BMEdge *e_find; |