#define MRMESH_API
Definition MRMesh/MRMeshFwd.h:68
auto end(const BitSet &)
Definition MRMesh/MRBitSet.h:288
MRMESH_API OneMeshContour convertSurfacePathWithEndsToMeshContour(const Mesh &mesh, const MeshTriPoint &start, const SurfacePath &surfacePath, const MeshTriPoint &end)
Converts SurfacePath to OneMeshContours.
MRMESH_API Expected< OneMeshContours > convertMeshTriPointsIsoLineToMeshContour(const Mesh &mesh, const std::vector< MeshTriPoint > &meshTriPoints, float isoValue, SearchPathSettings searchSettings={})
Makes continuous contour by iso-line from mesh tri points, if first and last meshTriPoint is the same...
MRMESH_API Expected< OneMeshContour, PathError > convertMeshTriPointsToMeshContour(const Mesh &mesh, const std::vector< MeshTriPoint > &meshTriPoints, SearchPathSettings searchSettings={}, std::vector< int > *pivotIndices=nullptr)
Makes continuous contour by mesh tri points, if first and last meshTriPoint is the same,...
MRMESH_API OneMeshContours convertSurfacePathsToMeshContours(const Mesh &mesh, const std::vector< SurfacePath > &surfacePaths)
Converts SurfacePaths to OneMeshContours.
std::vector< OneMeshContour > OneMeshContours
Special data type for MR::cutMesh.
Definition MRMesh/MRContoursCut.h:48
MRMESH_API Expected< OneMeshContour, PathError > convertMeshTriPointsToClosedContour(const Mesh &mesh, const std::vector< MeshTriPoint > &meshTriPoints, SearchPathSettings searchSettings={}, std::vector< int > *pivotIndices=nullptr)
Makes closed continuous contour by mesh tri points, note that first and last meshTriPoint should not ...
MRMESH_API CutMeshResult cutMesh(Mesh &mesh, const OneMeshContours &contours, const CutMeshParameters ¶ms={})
Cuts mesh by given contours.
GeodesicPathApprox
the algorithm to compute approximately geodesic path
Definition MRSurfacePath.h:41
@ DijkstraAStar
compute edge-only path using A*-search algorithm
MRMESH_API void subdivideLoneContours(Mesh &mesh, const OneMeshContours &contours, FaceHashMap *new2oldMap=nullptr)
tl::expected< T, E > Expected
Definition MRExpected.h:58
std::vector< MeshEdgePoint > SurfacePath
Definition MRMesh/MRMeshFwd.h:372
HashMap< FaceId, FaceId > FaceHashMap
Definition MRMesh/MRMeshFwd.h:486
std::vector< ContinuousContour > ContinuousContours
Definition MRMesh/MRIntersectionContour.h:18
std::function< Vector3i(const Vector3f &)> ConvertToIntVector
float-to-int coordinate converter
Definition MRMesh/MRPrecisePredicates3.h:47
phmap::flat_hash_map< K, V, Hash, Eq > HashMap
Definition MRMesh/MRMeshFwd.h:482
MRMESH_API OneMeshContours getOneMeshIntersectionContours(const Mesh &meshA, const Mesh &meshB, const ContinuousContours &contours, bool getMeshAIntersections, const CoordinateConverters &converters, const AffineXf3f *rigidB2A=nullptr)
this struct contains coordinate converters float-int-float
Definition MRMesh/MRPrecisePredicates3.h:52
Parameters of MR::cutMesh.
const SortIntersectionsData * sortData
Definition MRMesh/MRContoursCut.h:159
enum MR::CutMeshParameters::ForceFill None
FaceMap * new2OldMap
This is optional output - map from newly generated faces to old faces (N-1)
Definition MRMesh/MRContoursCut.h:161
NewEdgesMap * new2oldEdgesMap
Optional output map for each new edge introduced after cut maps edge from old topology or old face.
Definition MRMesh/MRContoursCut.h:174
ForceFill
Definition MRMesh/MRContoursCut.h:167
std::vector< EdgePath > resultCut
Paths of new edges on mesh, they represent same contours as input, but already cut.
Definition MRMesh/MRContoursCut.h:184
FaceBitSet fbsWithCountourIntersections
Definition MRMesh/MRContoursCut.h:187
Definition MRMesh/MRMeshTriPoint.h:23
Definition MRMesh/MRMesh.h:23
Definition MRMesh/MRContoursCut.h:136
HashMap< UndirectedEdgeId, int > map
Definition MRMesh/MRContoursCut.h:144
UndirectedEdgeBitSet splitEdges
Definition MRMesh/MRContoursCut.h:139
Definition MRMesh/MRContoursCut.h:37
std::vector< OneMeshIntersection > intersections
Definition MRMesh/MRContoursCut.h:38
bool closed
Definition MRMesh/MRContoursCut.h:39
Definition MRMesh/MRContoursCut.h:28
VariantIndex
Definition MRMesh/MRContoursCut.h:29
@ Edge
Definition MRMesh/MRContoursCut.h:29
@ Vertex
Definition MRMesh/MRContoursCut.h:29
@ Face
Definition MRMesh/MRContoursCut.h:29
std::variant< FaceId, EdgeId, VertId > primitiveId
Definition MRMesh/MRContoursCut.h:30
Vector3f coordinate
Definition MRMesh/MRContoursCut.h:32
Geo path search settings.
Definition MRMesh/MRContoursCut.h:63
GeodesicPathApprox geodesicPathApprox
the algorithm to compute approximately geodesic path
Definition MRMesh/MRContoursCut.h:64
int maxReduceIters
the maximum number of iterations to reduce approximate path length and convert it in geodesic path
Definition MRMesh/MRContoursCut.h:65
Definition MRMesh/MRContoursCut.h:17
const AffineXf3f * rigidB2A
Definition MRMesh/MRContoursCut.h:21
const ContinuousContours & contours
Definition MRMesh/MRContoursCut.h:19
ConvertToIntVector converter
Definition MRMesh/MRContoursCut.h:20
size_t meshAVertsNum
Definition MRMesh/MRContoursCut.h:22
bool isOtherA
Definition MRMesh/MRContoursCut.h:23
const Mesh & otherMesh
Definition MRMesh/MRContoursCut.h:18