3#include "MRPch/MRBindingMacros.h"
41 [[nodiscard]]
size_t edgeSize()
const {
return edges_.size(); }
44 [[nodiscard]]
size_t edgeCapacity()
const {
return edges_.capacity(); }
59 void edgeReserve(
size_t newCapacity ) { edges_.reserve( newCapacity ); }
88 [[nodiscard]] EdgeId
next( EdgeId he )
const { assert(he.valid());
return edges_[he].next; }
91 [[nodiscard]] EdgeId
prev( EdgeId he )
const { assert(he.valid());
return edges_[he].prev; }
94 [[nodiscard]] VertId
org( EdgeId he )
const { assert(he.valid());
return edges_[he].org; }
97 [[nodiscard]] VertId
dest( EdgeId he )
const { assert(he.valid());
return edges_[he.sym()].org; }
100 [[nodiscard]] FaceId
left( EdgeId he )
const { assert(he.valid());
return edges_[he].left; }
103 [[nodiscard]] FaceId
right( EdgeId he )
const { assert(he.valid());
return edges_[he.sym()].left; }
145 [[nodiscard]]
bool isTriVert( FaceId f, VertId v )
const {
auto vs =
getTriVerts( f );
return v == vs[0] || v == vs[1] || v == vs[2]; }
165 template <
typename T>
185 [[nodiscard]] EdgeId
edgeWithOrg( VertId a )
const { assert( a.valid() );
return a < int(edgePerVertex_.size()) ? edgePerVertex_[a] : EdgeId(); }
188 [[nodiscard]]
bool hasVert( VertId a )
const { assert( updateValids_ );
return validVerts_.test( a ); }
191 [[nodiscard]]
int numValidVerts()
const { assert( updateValids_ );
return numValidVerts_; }
197 [[nodiscard]] VertId
addVertId() { edgePerVertex_.emplace_back();
if ( updateValids_ ) { validVerts_.push_back(
false ); }
return edgePerVertex_.backId(); }
206 void vertReserve(
size_t newCapacity ) { edgePerVertex_.reserve( newCapacity );
if ( updateValids_ ) { validVerts_.reserve( newCapacity ); } }
209 [[nodiscard]]
size_t vertSize()
const {
return edgePerVertex_.size(); }
212 [[nodiscard]]
size_t vertCapacity()
const {
return edgePerVertex_.capacity(); }
215 [[nodiscard]]
const VertBitSet &
getValidVerts()
const { assert( updateValids_ );
return validVerts_; }
221 [[nodiscard]]
const VertBitSet &
getVertIds(
const VertBitSet * region )
const
223 assert( region || updateValids_ );
224 assert( !updateValids_ || !region || region->is_subset_of( validVerts_ ) );
225 return region ? *region : validVerts_;
233 [[nodiscard]] EdgeId
edgeWithLeft( FaceId a )
const { assert( a.valid() );
return a < int(edgePerFace_.size()) ? edgePerFace_[a] : EdgeId(); }
236 [[nodiscard]]
bool hasFace( FaceId a )
const { assert( updateValids_ );
return validFaces_.test( a ); }
251 [[nodiscard]]
int numValidFaces()
const { assert( updateValids_ );
return numValidFaces_; }
257 [[nodiscard]] FaceId
addFaceId() { edgePerFace_.emplace_back();
if ( updateValids_ ) { validFaces_.push_back(
false ); }
return edgePerFace_.backId(); }
272 void faceReserve(
size_t newCapacity ) { edgePerFace_.reserve( newCapacity );
if ( updateValids_ ) { validFaces_.reserve( newCapacity ); } }
275 [[nodiscard]]
size_t faceSize()
const {
return edgePerFace_.size(); }
278 [[nodiscard]]
size_t faceCapacity()
const {
return edgePerFace_.capacity(); }
281 [[nodiscard]]
const FaceBitSet &
getValidFaces()
const { assert( updateValids_ );
return validFaces_; }
287 [[nodiscard]]
const FaceBitSet &
getFaceIds(
const FaceBitSet * region )
const
289 assert( region || updateValids_ );
290 assert( !updateValids_ || !region || region->is_subset_of( validFaces_ ) );
291 return region ? *region : validFaces_;
344 [[nodiscard]]
MRMESH_API VertBitSet
findBdVerts(
const FaceBitSet * region =
nullptr,
const VertBitSet * test =
nullptr )
const;
458 FaceMap * outFmap =
nullptr, VertMap * outVmap =
nullptr, WholeEdgeMap * outEmap =
nullptr,
459 bool rearrangeTriangles =
false );
472 const std::vector<EdgePath> & thisContours = {},
const std::vector<EdgePath> & fromContours = {},
477 const std::vector<EdgePath> & thisContours = {},
const std::vector<EdgePath> & fromContours = {},
487 MRMESH_API void pack( FaceMap * outFmap =
nullptr, VertMap * outVmap =
nullptr, WholeEdgeMap * outEmap =
nullptr,
bool rearrangeTriangles =
false );
518 const FaceMap & fmap,
const VertMap & vmap );
552 void setOrg_( EdgeId a, VertId v );
558 void setLeft_( EdgeId a, FaceId f );
564 struct alignas( 16 ) HalfEdgeRecord
578 static_assert(
sizeof( HalfEdgeRecord ) == 16 );
581 template<
typename FM,
typename VM,
typename WEM>
582 void translateNoFlip_( HalfEdgeRecord & r,
const FM & fmap,
const VM & vmap,
const WEM & emap )
const;
583 template<
typename FM,
typename VM,
typename WEM>
584 void translate_( HalfEdgeRecord & r, HalfEdgeRecord & rsym,
585 const FM & fmap,
const VM & vmap,
const WEM & emap,
bool flipOrientation )
const;
592 VertBitSet validVerts_;
596 FaceBitSet validFaces_;
598 int numValidVerts_ = 0;
599 int numValidFaces_ = 0;
601 bool updateValids_ =
true;
612 if (
auto e = p.
onEdge( *
this ) )
614 callback(
org( e.e ) );
615 callback(
dest( e.e ) );
621 for (
int i = 0; i < 3; ++i )
631 auto testEdge =
prev( e.sym() );
632 if (
left( testEdge ) &&
right( testEdge ) && flipNeeded( testEdge ) )
649 if (
left( e ) &&
right( e ) && flipNeeded( e ) )
665template<
typename T,
typename I>
671 const auto& mData = map.
b.
data();
672 const auto sz = std::min( oldVector.
size(), map.
b.
size() );
673 for (
I i =
I(0); i < sz; ++i)
677 newVector[newV] = oldVector[i];
#define MRMESH_API
Definition MRMeshFwd.h:80
Definition MRMeshTopology.h:23
std::vector<T>-like container that requires specific indexing type,
Definition MRVector.h:23
bool contains(const TypedBitSet< I > *bitset, I id)
Definition MRBitSet.h:392
std::function< bool(float)> ProgressCallback
Definition MRMeshFwd.h:753
EdgeId collapseEdge(EdgeId e, const std::function< void(EdgeId del, EdgeId rem)> &onEdgeDel)
void flipEdgesIn(EdgeId e0, T &&flipNeeded)
Definition MRMeshTopology.h:626
MR_BIND_IGNORE void getTriVerts(FaceId f, VertId(&v)[3]) const
Definition MRMeshTopology.h:140
size_t faceCapacity() const
returns the number of allocated face records
Definition MRMeshTopology.h:278
VertId addVertId()
creates new vert-id not associated with any edge yet
Definition MRMeshTopology.h:197
Buffer< T, I > b
Definition MRBuffer.h:137
std::vector< EdgeId > EdgeLoop
Definition MRMeshFwd.h:148
bool fromSameLeftRing(EdgeId a, EdgeId b) const
returns true if a and b are both from the same left face ring
void excludeLoneEdges(UndirectedEdgeBitSet &edges) const
remove all lone edges from given set
EdgeId sharedVertInOrg(EdgeId a, EdgeId b) const
if two valid edges share the same vertex then it is found and returned as Edge with this vertex in or...
EdgeId splitEdge(EdgeId e, FaceBitSet *region=nullptr, FaceHashMap *new2Old=nullptr)
EdgeId makeEdge()
creates an edge not associated with any vertex or face
Turn
what way a path can follow in case of several alternatives
Definition MREnums.h:117
UndirectedEdgeId lastNotLoneUndirectedEdge() const
returns last not lone undirected edge id, or invalid id if no such edge exists
void getTriVerts(FaceId f, VertId &v0, VertId &v1, VertId &v2) const
Definition MRMeshTopology.h:139
void deleteFaces(const FaceBitSet &fs, const UndirectedEdgeBitSet *keepEdges=nullptr)
deletes multiple given faces by calling deleteFace for each
void getLeftTriEdges(EdgeId e0, EdgeId &e1, EdgeId &e2) const
MR_BIND_IGNORE VertBitSet findBoundaryVerts(const VertBitSet *region=nullptr) const
struct MRMESH_CLASS PartMapping
Definition MRMeshFwd.h:640
void packMinMem(const PackMapping &map)
bool computeValidsFromEdges(ProgressCallback cb={})
void flipEdgesOut(EdgeId e0, T &&flipNeeded)
Definition MRMeshTopology.h:644
VertId org
vertex at the origin of the edge
Definition MRMeshTopology.h:568
void faceReserve(size_t newCapacity)
sets the capacity of faces vector
Definition MRMeshTopology.h:272
bool isLeftInRegion(EdgeId e, const FaceBitSet *region=nullptr) const
return true if left face of given edge belongs to region (or just have valid id if region is nullptr)
Definition MRMeshTopology.h:314
void shrinkToFit()
requests the removal of unused capacity
std::size_t size() const
Definition MRVector.h:55
EdgeId sharedEdge(FaceId l, FaceId r) const
if two valid faces share the same edge then it is found and returned
void faceResize(size_t newSize)
explicitly increases the size of faces vector
size_t vertSize() const
returns the number of vertex records including invalid ones
Definition MRMeshTopology.h:209
void resize(size_t newSize) MR_REQUIRES_IF_SUPPORTED(sizeof(T)>0 &&std
Definition MRVector.h:57
EdgeId next(EdgeId he) const
next (counter clock wise) half-edge in the origin ring
Definition MRMeshTopology.h:88
EdgeId nextLeftBd(EdgeId e, const FaceBitSet *region=nullptr, Turn turn=Turn::Rightmost) const
int getVertDegree(VertId v) const
returns the number of edges around the given vertex
Definition MRMeshTopology.h:126
EdgeId sharedVertInOrg(FaceId l, FaceId r) const
if two valid faces share the same vertex then it is found and returned as Edge with this vertex in or...
EdgeId bdEdgeWithOrigin(VertId v, const FaceBitSet *region=nullptr) const
Definition MRMeshTopology.h:338
bool isBdEdge(EdgeId e, const FaceBitSet *region=nullptr) const
std::vector< EdgeId > findHoleRepresentiveEdges(const FaceBitSet *region=nullptr) const
bool hasVert(VertId a) const
returns true if given vertex is present in the mesh
Definition MRMeshTopology.h:188
FaceId left(EdgeId he) const
returns left face of half-edge
Definition MRMeshTopology.h:100
const Vector< EdgeId, VertId > & edgePerVertex() const
for all valid vertices this vector contains an edge with the origin there
Definition MRMeshTopology.h:182
void resizeBeforeParallelAdd(size_t edgeSize, size_t vertSize, size_t faceSize)
void vertResize(size_t newSize)
explicitly increases the size of vertices vector
Triangulation getTriangulation() const
EdgeId bdEdgeWithLeft(FaceId f, const FaceBitSet *region=nullptr) const
Definition MRMeshTopology.h:304
std::vector< ThreeVertIds > getAllTriVerts() const
returns three vertex ids for valid triangles, invalid triangles are skipped
void addPart(const MeshTopology &from, FaceMap *outFmap=nullptr, VertMap *outVmap=nullptr, WholeEdgeMap *outEmap=nullptr, bool rearrangeTriangles=false)
auto size() const
Definition MRBuffer.h:70
bool isInnerOrBdVertex(VertId v, const FaceBitSet *region=nullptr) const
returns true if one of incident faces of given vertex pertain to given region (or any such face exist...
FaceBitSet findBdFaces(const FaceBitSet *region=nullptr) const
returns all faces for which isBdFace(f, region) is true
VertId dest(EdgeId he) const
returns destination vertex of half-edge
Definition MRMeshTopology.h:97
FaceBitSet getPathRightFaces(const EdgePath &path) const
returns all valid right faces of path edges
int getOrgDegree(EdgeId a) const
returns the number of edges around the origin vertex, returns 1 for lone edges
bool updatingValids() const
returns whether the methods validVerts(), validFaces(), numValidVerts(), numValidFaces() can be calle...
Definition MRMeshTopology.h:530
void splice(EdgeId a, EdgeId b)
int getLeftDegree(EdgeId a) const
returns the number of edges around the left face: 3 for triangular faces, ...
MR_BIND_IGNORE FaceBitSet findBoundaryFaces(const FaceBitSet *region=nullptr) const
std::vector< EdgeLoop > getLeftRings(const std::vector< EdgeId > &es) const
void getTriEdges(FaceId f, EdgeId &e0, EdgeId &e1, EdgeId &e2) const
Definition MRMeshTopology.h:175
bool isLoneEdge(EdgeId a) const
checks whether the edge is disconnected from all other edges and disassociated from all vertices and ...
bool operator==(const HalfEdgeRecord &b) const
Definition MRMeshTopology.h:571
void faceResizeWithReserve(size_t newSize)
explicitly increases the size of faces vector, doubling the current capacity if it was not enough
UndirectedEdgeBitSet findNotLoneUndirectedEdges() const
finds and returns all not-lone (valid) undirected edges
HalfEdgeRecord() noexcept=default
bool hasFace(FaceId a) const
returns true if given face is present in the mesh
Definition MRMeshTopology.h:236
size_t edgeSize() const
returns the number of half-edge records including lone ones
Definition MRMeshTopology.h:41
EdgeId bdEdgeSameOrigin(EdgeId e, const FaceBitSet *region=nullptr) const
void flipOrientation(const UndirectedEdgeBitSet *fullComponents=nullptr)
bool isLeftQuad(EdgeId a) const
This one is not in the bindings because of the reference-to-array parameter.
FaceId lastValidFace() const
returns last valid face id, or invalid id if no single valid face exists
void vertResizeWithReserve(size_t newSize)
explicitly increases the size of vertices vector, doubling the current capacity if it was not enough
bool isLeftBdFace(EdgeId e, const FaceBitSet *region=nullptr) const
Definition MRMeshTopology.h:300
bool isInnerOrBdEdge(EdgeId e, const FaceBitSet *region=nullptr) const
return true if given edge is inner or boundary for given region (or for whole mesh if region is nullp...
Definition MRMeshTopology.h:353
bool isClosed(const FaceBitSet *region=nullptr) const
returns true if the mesh (region) does not have any neighboring holes
int getFaceDegree(FaceId f) const
returns the number of edges around the given face: 3 for triangular faces, ...
Definition MRMeshTopology.h:132
tl::expected< T, E > Expected
Definition MRExpected.h:31
void rotateTriangles()
for each triangle selects edgeWithLeft with minimal origin vertex
bool isBdFace(FaceId f, const FaceBitSet *region=nullptr) const
returns true if given face belongs to the region and it has a boundary edge (isBdEdge(e,...
Definition MRMeshTopology.h:307
EdgeLoop getLeftRing(EdgeId e) const
returns full edge-loop of left face from (e) starting from (e) itself
bool isLeftBdEdge(EdgeId e, const FaceBitSet *region=nullptr) const
returns true if left face of given edge belongs to given region (if provided) and right face either d...
Definition MRMeshTopology.h:350
int numValidVerts() const
returns the number of valid vertices
Definition MRMeshTopology.h:191
EdgeId prev
next clock wise half-edge in the origin ring
Definition MRMeshTopology.h:567
VertId org(EdgeId he) const
returns origin vertex of half-edge
Definition MRMeshTopology.h:94
VertBitSet findBdVerts(const FaceBitSet *region=nullptr, const VertBitSet *test=nullptr) const
returns all (test) vertices for which isBdVertex(v, region) is true
EdgeId edgeWithLeft(FaceId a) const
returns valid edge if given vertex is present in the mesh
Definition MRMeshTopology.h:233
auto data() MR_LIFETIMEBOUND
Definition MRBuffer.h:101
VertId splitFace(FaceId f, FaceBitSet *region=nullptr, FaceHashMap *new2Old=nullptr)
void flipEdgesIn(VertId v, T &&flipNeeded)
Definition MRMeshTopology.h:419
EdgeId prev(EdgeId he) const
previous (clock wise) half-edge in the origin ring
Definition MRMeshTopology.h:91
class MRMESH_CLASS I
Definition MRMeshFwd.h:137
void write(std::ostream &s) const
saves in binary stream
size_t tsize
target size, all values inside b must be less than this value
Definition MRBuffer.h:138
ThreeVertIds getTriVerts(FaceId f) const
Definition MRMeshTopology.h:142
EdgeId lastNotLoneEdge() const
returns last not lone edge id, or invalid id if no such edge exists
Definition MRMeshTopology.h:35
void addPartByMask(const MeshTopology &from, const FaceBitSet *fromFaces, const PartMapping &map={})
the same but copies only portion of (from) specified by fromFaces,
EdgeId findEdge(VertId o, VertId d) const
finds and returns edge from o to d in the mesh; returns invalid edge otherwise
bool isInnerEdge(EdgeId e, const FaceBitSet *region=nullptr) const
return true if given edge is inner for given region (or for whole mesh if region is nullptr)
Definition MRMeshTopology.h:317
void addPackedPart(const MeshTopology &from, EdgeId toEdgeId, const FaceMap &fmap, const VertMap &vmap)
HashMap< FaceId, FaceId > FaceHashMap
Definition MRMeshFwd.h:610
size_t edgeCapacity() const
returns the number of allocated edge records
Definition MRMeshTopology.h:44
int numValidFaces() const
returns the number of valid faces
Definition MRMeshTopology.h:251
size_t heapBytes() const
returns the amount of memory this object occupies on heap
MR_BIND_IGNORE EdgeBitSet findBoundaryEdges() const
returns all boundary edges, where each edge does not have valid left face
size_t computeNotLoneUndirectedEdges() const
computes the number of not-lone (valid) undirected edges
EdgeId edgeWithOrg(VertId a) const
returns valid edge if given vertex is present in the mesh
Definition MRMeshTopology.h:185
size_t faceSize() const
returns the number of face records including invalid ones
Definition MRMeshTopology.h:275
MR_BIND_IGNORE void addPartByMask(const MeshTopology &from, const FaceBitSet &fromFaces, const PartMapping &map={})
This is skipped in the bindings because it conflicts with the overload taking a pointer in C#....
Definition MRMeshTopology.h:464
void deleteFace(FaceId f, const UndirectedEdgeBitSet *keepEdges=nullptr)
deletes the face, also deletes its edges and vertices if they were not shared by other faces and not ...
void setLeft(EdgeId a, FaceId f)
MR_BIND_IGNORE void getTriEdges(FaceId f, EdgeId(&e)[3]) const
Definition MRMeshTopology.h:176
void edgeReserve(size_t newCapacity)
sets the capacity of half-edges vector
Definition MRMeshTopology.h:59
std::vector< EdgeId > EdgePath
Definition MRMeshFwd.h:147
std::array< VertId, 3 > ThreeVertIds
three vertex ids describing a triangle with the corners in vertices given by their ids
Definition MRMeshFwd.h:519
void getLeftTriVerts(EdgeId a, ThreeVertIds &v) const
This one is not in the bindings because of the reference-to-array parameter.
Definition MRMeshTopology.h:158
int findNumHoles(EdgeBitSet *holeRepresentativeEdges=nullptr) const
EdgeId next
next counter clock wise half-edge in the origin ring
Definition MRMeshTopology.h:566
constexpr NoInit noInit
Definition MRMeshFwd.h:98
void forEachVertex(const MeshTriPoint &p, T &&callback) const
Definition MRMeshTopology.h:605
Vector< T, I > rearrangeVectorByMap(const Vector< T, I > &oldVector, const BMap< I, I > &map)
rearrange vector values by map (old.id -> new.id)
Definition MRMeshTopology.h:666
VertBitSet getPathVertices(const EdgePath &path) const
returns all vertices incident to path edges
void pack(FaceMap *outFmap=nullptr, VertMap *outVmap=nullptr, WholeEdgeMap *outEmap=nullptr, bool rearrangeTriangles=false)
EdgeId bdEdgeSameLeft(EdgeId e, const FaceBitSet *region=nullptr) const
void setOrg(EdgeId a, VertId v)
void addPart(const MeshTopology &from, const PartMapping &map={}, bool rearrangeTriangles=false)
FaceBitSet getPathLeftFaces(const EdgePath &path) const
returns all valid left faces of path edges
FaceId addFaceId()
creates new face-id not associated with any edge yet
Definition MRMeshTopology.h:257
void flipEdgesOut(VertId v, T &&flipNeeded)
Definition MRMeshTopology.h:429
FaceId left
face at the left of the edge
Definition MRMeshTopology.h:569
EdgeId prevLeftBd(EdgeId e, const FaceBitSet *region=nullptr, Turn turn=Turn::Rightmost) const
bool buildGridMesh(const GridSettings &settings, ProgressCallback cb={})
constructs triangular grid mesh topology in parallel
void preferEdges(const UndirectedEdgeBitSet &stableEdges)
void stopUpdatingValids()
stops updating validVerts(), validFaces(), numValidVerts(), numValidFaces() for parallel processing o...
FaceId sharedFace(EdgeId a, EdgeId b) const
if two valid edges belong to same valid face then it is found and returned
std::array< Vector3f, 3 > MR_BIND_IGNORE
Definition MRMeshBuilderTypes.h:13
size_t undirectedEdgeSize() const
returns the number of undirected edges (pairs of half-edges) including lone ones
Definition MRMeshTopology.h:47
void vertReserve(size_t newCapacity)
sets the capacity of vertices vector
Definition MRMeshTopology.h:206
friend class MeshTopologyDiff
Definition MRMeshTopology.h:544
void flip(VertBitSet &vs) const
sets in (vs) all valid vertices that were not selected before the call, and resets other bits
Definition MRMeshTopology.h:218
void getTriVerts(FaceId f, ThreeVertIds &v) const
This one is not in the bindings because of the reference-to-array parameter.
Definition MRMeshTopology.h:141
bool fromSameOriginRing(EdgeId a, EdgeId b) const
returns true if a and b are both from the same origin ring
void getLeftTriVerts(EdgeId a, VertId &v0, VertId &v1, VertId &v2) const
bool isLeftTri(EdgeId a) const
returns true if the cell to the left of a is triangular
FaceId right(EdgeId he) const
returns right face of half-edge
Definition MRMeshTopology.h:103
MR_BIND_IGNORE void getLeftTriVerts(EdgeId a, VertId(&v)[3]) const
Definition MRMeshTopology.h:157
bool checkValidity(ProgressCallback cb={}, bool allVerts=true) const
bool hasEdge(EdgeId e) const
returns true if given edge is within valid range and not-lone
Definition MRMeshTopology.h:62
bool operator==(const MeshTopology &b) const
compare that two topologies are exactly the same
void addPartByMask(const MeshTopology &from, const FaceBitSet *fromFaces, bool flipOrientation=false, const std::vector< EdgePath > &thisContours={}, const std::vector< EdgePath > &fromContours={}, const PartMapping &map={})
const VertBitSet & getVertIds(const VertBitSet *region) const
if region pointer is not null then converts it in reference, otherwise returns all valid vertices in ...
Definition MRMeshTopology.h:221
const Vector< EdgeId, FaceId > & edgePerFace() const
for all valid faces this vector contains an edge with that face at left
Definition MRMeshTopology.h:230
MR_BIND_IGNORE void addPartByMask(const MeshTopology &from, const FaceBitSet &fromFaces, bool flipOrientation=false, const std::vector< EdgePath > &thisContours={}, const std::vector< EdgePath > &fromContours={}, const PartMapping &map={})
This is skipped in the bindings because it conflicts with the overload taking a pointer in C#....
Definition MRMeshTopology.h:476
void pack(const PackMapping &map)
bool isBdVertex(VertId v, const FaceBitSet *region=nullptr) const
returns true if given vertex is on (region) boundary
Definition MRMeshTopology.h:341
bool isBdVertexInOrg(EdgeId e, const FaceBitSet *region=nullptr) const
returns true if edge's origin is on (region) boundary
Definition MRMeshTopology.h:334
Expected< void > read(std::istream &s, ProgressCallback callback={})
const VertBitSet & getValidVerts() const
returns cached set of all valid vertices
Definition MRMeshTopology.h:215
size_t undirectedEdgeCapacity() const
returns the number of allocated undirected edges (pairs of half-edges)
Definition MRMeshTopology.h:50
void flip(FaceBitSet &fs) const
sets in (fs) all valid faces that were not selected before the call, and resets other bits
Definition MRMeshTopology.h:284
ThreeVertIds getLeftTriVerts(EdgeId a) const
Definition MRMeshTopology.h:159
MeshEdgePoint onEdge(const MeshTopology &topology) const
bool isTriVert(FaceId f, VertId v) const
return true if triangular face (f) has (v) as one of its vertices
Definition MRMeshTopology.h:145
EdgeBitSet findLeftBdEdges(const FaceBitSet *region=nullptr, const EdgeBitSet *test=nullptr) const
returns all (test) edges for which left(e) does not belong to the region and isBdEdge(e,...
const FaceBitSet & getValidFaces() const
returns cached set of all valid faces
Definition MRMeshTopology.h:281
const FaceBitSet & getFaceIds(const FaceBitSet *region) const
if region pointer is not null then converts it in reference, otherwise returns all valid faces in the...
Definition MRMeshTopology.h:287
EdgeId e
Definition MRMeshTriPoint.h:27
VertId lastValidVert() const
returns last valid vertex id, or invalid id if no single valid vertex exists
VertId inVertex(const MeshTopology &topology) const
returns valid vertex id if the point is in vertex, otherwise returns invalid id
size_t vertCapacity() const
returns the number of allocated vert records
Definition MRMeshTopology.h:212
@ Rightmost
Definition MREnums.h:119
only for bindings generation
Definition MRCameraOrientationPlugin.h:8
flat map: I -> T
Definition MRBuffer.h:136
settings defining regular grid, where each quadrangular cell is split on two triangles in one of two ...
Definition MRGridSettings.h:14
Definition MRMeshTriPoint.h:26
Definition MRMeshFwd.h:97
Definition MRBuffer.h:144
mapping among elements of source mesh, from which a part is taken, and target mesh
Definition MRPartMapping.h:13