6#include "MRPch/MRBindingMacros.h"
22 #if !defined _ITERATOR_DEBUG_LEVEL
23 #define _ITERATOR_DEBUG_LEVEL 0
25 #if !defined MR_ITERATOR_DEBUG_LEVEL
26 #define MR_ITERATOR_DEBUG_LEVEL 0
28 #if _ITERATOR_DEBUG_LEVEL != MR_ITERATOR_DEBUG_LEVEL
29 #error _ITERATOR_DEBUG_LEVEL is inconsistent with MeshLib
35#define MR_CPP_STANDARD_DATE _MSVC_LANG
37#define MR_CPP_STANDARD_DATE __cplusplus
44#if MR_CPP_STANDARD_DATE < 201709 && !defined(__CUDACC__)
45#error Must enable C++20 or newer!
55#if defined(__GNUC__) && (__GNUC__ >= 13 && __GNUC__ <= 15)
56 #pragma GCC diagnostic push
57 #pragma GCC diagnostic ignored "-Warray-bounds"
58 #pragma GCC diagnostic ignored "-Wstringop-overflow"
63#if defined(__GNUC__) && (__GNUC__ >= 13 && __GNUC__ <= 15)
64 #pragma GCC diagnostic pop
69#include <parallel_hashmap/phmap_fwd_decl.h>
74# define MRMESH_API __declspec(dllexport)
76# define MRMESH_API __declspec(dllimport)
80# define MRMESH_API __attribute__((visibility("default")))
85# define MRMESH_CLASS __attribute__((type_visibility("default")))
87# define MRMESH_CLASS __attribute__((visibility("default")))
157 ( UndirectedEdgeBitSet,
TypedBitSet<UndirectedEdgeId> )
176 ( UndirectedEdgeSetBitIterator,
SetBitIteratorT<UndirectedEdgeBitSet> )
195using Int64 = std::ptrdiff_t;
196using Uint64 = std::size_t;
197static_assert(
sizeof(
Int64) == 8);
198static_assert(
sizeof(
Uint64) == 8);
214#if !MR_PARSING_FOR_ANY_BINDINGS
225#if !MR_PARSING_FOR_ANY_BINDINGS
236#if !MR_PARSING_FOR_ANY_BINDINGS
247#if !MR_PARSING_FOR_ANY_BINDINGS
258#if !MR_PARSING_FOR_ANY_BINDINGS
269#if !MR_PARSING_FOR_ANY_BINDINGS
280#if !MR_PARSING_FOR_ANY_BINDINGS
291#if !MR_PARSING_FOR_ANY_BINDINGS
302#if !MR_PARSING_FOR_ANY_BINDINGS
343template <typename T> using Line2 =
Line<
Vector2<T>>;
372 ( Cone3d,
Cone3<
double> )
376template <typename V> using
Contour = std::vector<V>;
394 ( Plane3d,
Plane3<
double> )
400 ( Box1f,
Box<
float> )
401 ( Box1d,
Box<
double> )
411#if !MR_PARSING_FOR_ANY_BINDINGS
412using Box1ll [[deprecated(
"Use `Box1i64` instead.")]] =
Box<long long>;
426template<
typename T,
typename I>
struct MinArg;
427template<
typename T,
typename I>
struct MaxArg;
428template<
typename T,
typename I>
struct MinMaxArg;
466template <typename T> using Triangle3 = std::array<
Vector3<T>, 3>;
538 ( FaceMap,
Vector<FaceId, FaceId> )
539 ( VertMap,
Vector<VertId, VertId> )
540 ( EdgeMap,
Vector<EdgeId, EdgeId> )
541 ( UndirectedEdgeMap,
Vector<UndirectedEdgeId, UndirectedEdgeId> )
542 ( ObjMap,
Vector<ObjId, ObjId> )
545 ( WholeEdgeMap,
Vector<EdgeId, UndirectedEdgeId> )
546 ( UndirectedEdge2RegionMap,
Vector<RegionId, UndirectedEdgeId> )
547 ( Face2RegionMap,
Vector<RegionId, FaceId> )
548 ( Vert2RegionMap,
Vector<RegionId, VertId> )
550 ( VertCoords,
Vector<Vector3f, VertId> )
551 ( VertCoords2,
Vector<Vector2f, VertId> )
552 ( VertNormals,
Vector<Vector3f, VertId> )
554 ( FaceNormals,
Vector<Vector3f, FaceId> )
556 ( TexturePerFace,
Vector<TextureId, FaceId> )
560 ( UndirectedEdgeColors,
Vector<
Color, UndirectedEdgeId> )
562 ( VertScalars,
Vector<
float, VertId> )
563 ( FaceScalars,
Vector<
float, FaceId> )
564 ( EdgeScalars,
Vector<
float, EdgeId> )
565 ( UndirectedEdgeScalars,
Vector<
float, UndirectedEdgeId> )
568using VertPredicate = std::function<
bool( VertId )>;
577[[nodiscard]] inline
bool contains( const std::function<
bool(
Id<T> )> & pred,
Id<T>
id )
579 return id.valid() && ( !pred || pred(
id ) );
595template <typename T, typename
Hash = phmap::priv::hash_default_hash<T>, typename
Eq = phmap::priv::hash_default_eq<T>>
596using HashSet = phmap::flat_hash_set<T,
Hash,
Eq>;
597template <typename T, typename
Hash = phmap::priv::hash_default_hash<T>, typename
Eq = phmap::priv::hash_default_eq<T>>
605template <typename K, typename V, typename
Hash = phmap::priv::hash_default_hash<K>, typename
Eq = phmap::priv::hash_default_eq<K>>
607template <typename K, typename V, typename
Hash = phmap::priv::hash_default_hash<K>, typename
Eq = phmap::priv::hash_default_eq<K>>
617template <typename K, typename V>
628template <typename T, typename
I, typename P> class
Heap;
748namespace ObjectSave {
struct Settings; }
763constexpr inline T
sqr( T x )
noexcept {
return x * x; }
767constexpr inline int sgn( T x )
noexcept {
return x > 0 ? 1 : ( x < 0 ? -1 : 0 ); }
771constexpr inline T
distance( T x, T y )
noexcept {
return x >= y ? x - y : y - x; }
778template <
typename V,
typename T>
779constexpr inline auto lerp( V v0, V v1, T t )
noexcept {
return ( 1 - t ) * v0 + t * v1; }
800struct VertDuplication;
809constexpr inline auto translate_noop(
const char* ctx,
const char* str )
noexcept { (void)ctx;
return str; }
810constexpr inline auto translate_noop(
const char* single,
const char* plural,
Int64 n )
noexcept {
return n == 1 ? single : plural; }
811constexpr inline auto translate_noop(
const char* ctx,
const char* single,
const char* plural,
Int64 n )
noexcept { (void)ctx;
return n == 1 ? single : plural; }
817#ifdef __cpp_lib_unreachable
818# define MR_UNREACHABLE std::unreachable();
819# define MR_UNREACHABLE_NO_RETURN std::unreachable();
822# define MR_UNREACHABLE __builtin_unreachable();
823# define MR_UNREACHABLE_NO_RETURN __builtin_unreachable();
826# define MR_UNREACHABLE { assert( false ); return {}; }
827# define MR_UNREACHABLE_NO_RETURN assert( false );
831#ifndef MR_NO_I18N_MACROS
832#define _t( ... ) MR::Locale::translate_noop( __VA_ARGS__ )
#define MR_CANONICAL_TYPEDEFS(type_, name_, aliases_)
Definition MRCanonicalTypedefs.h:23
#define MRMESH_CLASS
Definition MRMeshFwd.h:87
Definition MRAABBTreeObjects.h:22
bounding volume hierarchy for point cloud structure
Definition MRAABBTreePoints.h:16
bounding volume hierarchy for line segments
Definition MRAABBTreePolyline.h:30
Definition MRAABBTree.h:16
Definition MRVisualObject.h:53
accumulates a number of (x,y) points to find the best-least-squares parabola approximating them
Definition MRBestFitParabola.h:15
std::vector<V>-like container that is 1) resized without initialization of its elements,...
Definition MRBuffer.h:58
Undo action for ObjectMesh mesh change.
Definition MRChangeMeshAction.h:16
Undo action for ObjectMesh creases.
Definition MRChangeSelectionAction.h:122
Undo action for ObjectMeshData change.
Definition MRChangeMeshDataAction.h:14
Undo action for ObjectMesh edge selection.
Definition MRChangeSelectionAction.h:68
Undo action for ObjectMesh face selection.
Definition MRChangeSelectionAction.h:14
Undo action for ObjectMesh points only (not topology) change.
Definition MRChangeMeshAction.h:190
Undo action for ObjectMesh topology only (not points) change.
Definition MRChangeMeshAction.h:254
Definition MRChangeObjectAction.h:17
Undo action for ObjectPoints point selection.
Definition MRChangeSelectionAction.h:176
Definition MRChangeSceneAction.h:16
Definition MRChangeXfAction.h:16
Definition MRCircleObject.h:17
Class for aggregate several color map in one Color maps are aggregated according order.
Definition MRColorMapAggregator.h:20
Definition MRCombinedHistoryAction.h:15
Base class for cone parameterization.
Definition MRCone3.h:14
Definition MRConeObject.h:22
Definition MRCylinder3.h:15
Definition MRCylinderObject.h:21
Definition MRDistanceMap.h:24
the class stores some number of smallest elements from a larger number of candidates
Definition MRFewSmallest.h:17
mathematical graph consisting from vertices and undirected edges
Definition MRGraph.h:17
stores map from element id in[0, size) to T;
Definition MRHeap.h:23
Definition MRHistoryAction.h:15
Abstract class for fast approximate computation of generalized winding number for a mesh (using its A...
Definition MRFastWindingNumber.h:15
abstract class for computing the closest points of point clouds
Definition MRPointsProject.h:93
Abstract class, computes the closest point on mesh to each of given points. Pure virtual functions mu...
Definition MRPointsToMeshProjector.h:16
stores index of some element, it is made as template class to avoid mixing faces, edges and vertices
Definition MRId.h:19
Definition MRLaplacian.h:24
Definition MRLineObject.h:16
Definition MRMeshOrPoints.h:21
Definition MRMeshTopology.h:23
Variant of Id<T> with omitted initialization by default. Useful for containers.
Definition MRId.h:80
Definition MRObjectDistanceMap.h:16
Definition MRObjectGcode.h:17
Definition MRObjectLabel.h:29
Definition MRObjectLinesHolder.h:30
Definition MRObjectLines.h:14
Definition MRObjectMeshHolder.h:35
Definition MRObjectMesh.h:14
Definition MRObjectPointsHolder.h:24
Definition MRObjectPoints.h:14
named object in the data model
Definition MRObject.h:62
Undo action for efficiently storage of partial change in mesh (e.g. a modification of small region)
Definition MRPartialChangeMeshAction.h:25
Undo action for efficiently storage of partial change in mesh points (e.g. a modification of small re...
Definition MRPartialChangeMeshAction.h:85
Undo action for efficiently storage of partial change in mesh topology (e.g. a modification of small ...
Definition MRPartialChangeMeshAction.h:151
Definition MRPlaneObject.h:15
Class to accumulate points and make best line / plane approximation.
Definition MRBestFit.h:20
Definition MRPointObject.h:17
Definition MRPolylineTopology.h:18
Object that is parent of all scene.
Definition MRSceneRoot.h:14
iterator to enumerate all indices with set bits in BitSet class or its derivatives
Definition MRBitSet.h:24
Definition MRSharedThreadSafeOwner.h:19
Definition MRSphereObject.h:18
Definition MRSwapRootAction.h:16
Definition MRBitSet.h:277
Union-find data structure for representing disjoin sets of elements with few very quick operations: 1...
Definition MRUnionFind.h:23
Definition MRUniqueThreadSafeOwner.h:18
std::vector<T>-like container that requires specific indexing type,
Definition MRVector.h:23
Definition MRVersatileChangeMeshAction.h:14
Definition MRViewportId.h:16
stores mask of viewport unique identifiers
Definition MRViewportId.h:42
Visual Object.
Definition MRVisualObject.h:115
graphs representing rain basins on the mesh
Definition MRWatershedGraph.h:15
bool contains(const TypedBitSet< I > *bitset, I id)
Definition MRBitSet.h:392
std::function< bool(float)> ProgressCallback
Definition MRMeshFwd.h:753
CubicBezierCurve< Vector2< T > > CubicBezierCurve2
Definition MRMeshFwd.h:448
std::function< float(VertId)> VertMetric
Definition MRMeshFwd.h:582
phmap::parallel_flat_hash_map< K, V, Hash, Eq > ParallelHashMap
Definition MRMeshFwd.h:608
std::vector< EdgeId > EdgeLoop
Definition MRMeshFwd.h:148
std::vector< std::string > GcodeSource
Definition MRMeshFwd.h:684
RigidXf3f
Definition MRMeshFwd.h:316
WrapType
Definition MREnums.h:18
LineSegm2f
Definition MRMeshFwd.h:347
struct
Definition MRMeshFwd.h:204
Contour
Definition MRObjectLabel.h:20
std::array< VertId, 2 > TwoVertIds
two vertex ids describing an edge with the ends in vertices given by their ids
Definition MRMeshFwd.h:516
MRMESH_CLASS Vector2b
Definition MRMeshFwd.h:205
std::vector< SurfacePath > SurfacePaths
Definition MRMeshFwd.h:482
std::vector< EdgeLoop > EdgeLoops
Definition MRMeshFwd.h:149
Contour3< float > Contour3f
Definition MRMeshFwd.h:382
class MRMESH_CLASS UndirectedEdgeTag
Definition MRMeshFwd.h:102
constexpr T sqr(T x) noexcept
squared value
Definition MRMeshFwd.h:763
Cylinder3f
Definition MRMeshFwd.h:366
AABBTreePolyline2
Definition MRMeshFwd.h:663
LineSegm< Vector3< T > > LineSegm3
Definition MRMeshFwd.h:353
MapOrHashMap< FaceId, FaceId > FaceMapOrHashMap
Definition MRMeshFwd.h:620
class MRMESH_CLASS ObjTag
Definition MRMeshFwd.h:109
CubicBezierCurve< Vector3< T > > CubicBezierCurve3
Definition MRMeshFwd.h:449
Box< T > MinMax
Definition MRMeshFwd.h:417
Edges
Definition MRObjectMeshHolder.h:19
std::function< bool(FaceId)> FacePredicate
Definition MRMeshFwd.h:569
MinMax< float > MinMaxf
Definition MRMeshFwd.h:418
Contour2< double > Contour2d
Definition MRMeshFwd.h:379
struct MRMESH_CLASS Eq
Definition MRMeshFwd.h:595
class MRMESH_CLASS NodeTag
Definition MRMeshFwd.h:108
Box< Vector3< T > > Box3
Definition MRMeshFwd.h:424
HashSet< VertId > VertHashSet
Definition MRMeshFwd.h:602
TriPointf
Definition MRMeshFwd.h:497
std::function< bool(EdgeId)> EdgePredicate
Definition MRMeshFwd.h:570
Contour2< float > Contour2f
Definition MRMeshFwd.h:380
std::array< UVCoord, 3 > ThreeUVCoords
three UV-coordinates describing texturing of a triangle
Definition MRMeshFwd.h:522
SymMatrix2b
Definition MRMeshFwd.h:274
Contours2< double > Contours2d
Definition MRMeshFwd.h:387
Contours3< float > Contours3f
Definition MRMeshFwd.h:390
std::uint64_t Uint64
Definition MRMeshFwd.h:201
std::function< bool(UndirectedEdgeId)> UndirectedEdgePredicate
Definition MRMeshFwd.h:571
Ball< Vector2< T > > Ball2
Definition MRMeshFwd.h:439
MapOrHashMap< VertId, VertId > VertMapOrHashMap
Definition MRMeshFwd.h:621
Contours3< double > Contours3d
Definition MRMeshFwd.h:389
SurfacePaths PlaneSections
Definition MRMeshFwd.h:486
MapOrHashMap< EdgeId, EdgeId > EdgeMapOrHashMap
Definition MRMeshFwd.h:622
HashMap< VertId, VertId > VertHashMap
Definition MRMeshFwd.h:611
QuadraticForm2f
Definition MRMeshFwd.h:452
QuadraticForm< Vector3< T > > QuadraticForm3
Definition MRMeshFwd.h:458
class MRMESH_CLASS VoxelTag
Definition MRMeshFwd.h:106
Ball< T > Ball1
Definition MRMeshFwd.h:438
FilterType
Definition MREnums.h:12
Plane3f
Definition MRMeshFwd.h:393
SurfacePath IsoLine
Definition MRMeshFwd.h:483
Vector2f UVCoord
Definition MRMeshFwd.h:513
Triangle3< int > Triangle3i
Definition MRMeshFwd.h:467
Ball< Vector3< T > > Ball3
Definition MRMeshFwd.h:440
MRMESH_CLASS Vector3b
Definition MRMeshFwd.h:219
Sphere< Vector3< T > > Sphere3
Definition MRMeshFwd.h:335
std::vector< MeshEdgePoint > SurfacePath
Definition MRMeshFwd.h:481
HashMap< UndirectedEdgeId, EdgeId > WholeEdgeHashMap
mapping of whole edges: map[e]->f, map[e.sym()]->f.sym(), where only map[e] for even edges is stored
Definition MRMeshFwd.h:615
class MRMESH_CLASS FaceTag
Definition MRMeshFwd.h:103
class MRMESH_CLASS TextureTag
Definition MRMeshFwd.h:110
class MRMESH_CLASS I
Definition MRMeshFwd.h:137
class MRMESH_CLASS PixelTag
Definition MRMeshFwd.h:105
Line< Vector3< T > > Line3
Definition MRMeshFwd.h:344
Contours< Vector2< T > > Contours2
Definition MRMeshFwd.h:385
overloaded(Ts...) -> overloaded< Ts... >
explicit deduction guide (not needed as of C++20, but still needed in Clang)
constexpr int sgn(T x) noexcept
sign of given value in { -1, 0, 1 }
Definition MRMeshFwd.h:767
Contours2< float > Contours2f
Definition MRMeshFwd.h:388
RigidScaleXf3f
Definition MRMeshFwd.h:321
std::function< float(EdgeId)> EdgeMetric
Definition MRMeshFwd.h:584
MinMax< double > MinMaxd
Definition MRMeshFwd.h:419
Box< Vector2< T > > Box2
Definition MRMeshFwd.h:423
std::function< bool(EdgeId edgeToCollapse, const Vector3f &newEdgeOrgPos)> PreCollapseCallback
Definition MRMeshFwd.h:573
MinMax< int > MinMaxi
Definition MRMeshFwd.h:420
EdgePoint MeshEdgePoint
Definition MRMeshFwd.h:480
Box< T > Box1
Definition MRMeshFwd.h:422
Contour< Vector2< T > > Contour2
Definition MRMeshFwd.h:377
Contour3< double > Contour3d
Definition MRMeshFwd.h:381
TypedBitSet< Id< T > > TaggedBitSet
Definition MRMeshFwd.h:169
SurfacePath PlaneSection
Definition MRMeshFwd.h:485
HashMap< FaceId, FaceId > FaceHashMap
Definition MRMeshFwd.h:610
std::function< float(FaceId)> FaceMetric
Definition MRMeshFwd.h:583
MapOrHashMap< UndirectedEdgeId, EdgeId > WholeEdgeMapOrHashMap
mapping of whole edges: map[e]->f, map[e.sym()]->f.sym(), where only map[e] for even edges is stored
Definition MRMeshFwd.h:625
Polyline2
Definition MRMeshFwd.h:658
Triangle3< double > Triangle3d
Definition MRMeshFwd.h:469
Box1i
Definition MRMeshFwd.h:398
Contour< Vector3< T > > Contour3
Definition MRMeshFwd.h:378
HashSet< FaceId > FaceHashSet
No canonical typedefs because phmap::... is not under our control.
Definition MRMeshFwd.h:601
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
Matrix2b
Definition MRMeshFwd.h:241
class MRMESH_CLASS VertTag
Definition MRMeshFwd.h:104
std::pair< FaceId, FaceId > FacePair
Definition MRMeshFwd.h:492
constexpr NoInit noInit
Definition MRMeshFwd.h:98
SymMatrix3b
Definition MRMeshFwd.h:285
HashSet< EdgeId > EdgeHashSet
Definition MRMeshFwd.h:603
std::pair< UndirectedEdgeId, UndirectedEdgeId > UndirectedEdgePair
Definition MRMeshFwd.h:494
Cone3f
Definition MRMeshFwd.h:371
BestFitParabolaf
Definition MRMeshFwd.h:361
Quaternionf
Definition MRMeshFwd.h:461
std::pair< EdgeId, EdgeId > EdgePair
Definition MRMeshFwd.h:493
std::int64_t Int64
Definition MRMeshFwd.h:200
std::function< void(EdgeId e1, EdgeId e)> OnEdgeSplit
Definition MRMeshFwd.h:574
std::function< float(UndirectedEdgeId)> UndirectedEdgeMetric
Definition MRMeshFwd.h:585
AffineXf2f
Definition MRMeshFwd.h:307
Line2f
Definition MRMeshFwd.h:338
constexpr auto lerp(V v0, V v1, T t) noexcept
Linear interpolation: returns v0 when t==0 and v1 when t==1.
Definition MRMeshFwd.h:779
constexpr bool dependent_false
Definition MRMeshFwd.h:782
Triangle3< float > Triangle3f
Definition MRMeshFwd.h:468
SurfacePaths IsoLines
Definition MRMeshFwd.h:484
constexpr auto translate_noop(const char *str) noexcept
special no-op inline functions to mark string literal as translatable
Definition MRMeshFwd.h:808
class MRMESH_CLASS EdgeTag
Definition MRMeshFwd.h:101
AffineXf< Vector3< T > > AffineXf3
Definition MRMeshFwd.h:313
Vector4b
Definition MRMeshFwd.h:230
std::vector< Contour< V > > Contours
Definition MRMeshFwd.h:384
Polyline2ProjectionWithOffsetResult
Definition MRMeshFwd.h:676
HashMap< EdgeId, EdgeId > EdgeHashMap
Definition MRMeshFwd.h:612
struct MRMESH_CLASS Hash
Definition MRMeshFwd.h:595
phmap::parallel_flat_hash_set< T, Hash, Eq > ParallelHashSet
Definition MRMeshFwd.h:598
SegmPointf
Definition MRMeshFwd.h:474
Parabolaf
Definition MRMeshFwd.h:356
MapOrHashMap< UndirectedEdgeId, UndirectedEdgeId > UndirectedEdgeMapOrHashMap
Definition MRMeshFwd.h:623
std::pair< VertId, VertId > VertPair
Definition MRMeshFwd.h:491
Matrix3b
Definition MRMeshFwd.h:252
HashMap< UndirectedEdgeId, UndirectedEdgeId > UndirectedEdgeHashMap
Definition MRMeshFwd.h:613
Contours< Vector3< T > > Contours3
Definition MRMeshFwd.h:386
class MRMESH_CLASS RegionTag
Definition MRMeshFwd.h:107
Sphere2f
Definition MRMeshFwd.h:329
class MRMESH_CLASS GraphVertTag
Definition MRMeshFwd.h:111
phmap::flat_hash_map< K, V, Hash, Eq > HashMap
Definition MRMeshFwd.h:606
class MRMESH_CLASS GraphEdgeTag
Definition MRMeshFwd.h:112
SymMatrix4b
Definition MRMeshFwd.h:296
Matrix4b
Definition MRMeshFwd.h:263
Reorder
determines how points to be ordered
Definition MREnums.h:26
std::optional< T > distanceSq(const Plane3< T > &plane1, const Plane3< T > &plane2, T errorLimit=std::numeric_limits< T >::epsilon() *T(20))
Definition MRIntersection.h:90
std::optional< T > distance(const Plane3< T > &plane1, const Plane3< T > &plane2, T errorLimit=std::numeric_limits< T >::epsilon() *T(20))
Definition MRIntersection.h:104
Definition MRMeshFwd.h:805
Building topologies by triangles.
Definition MRIdentifyVertices.h:16
Definition MRIOFormatsRegistry.h:361
only for bindings generation
Definition MRCameraOrientationPlugin.h:8
Definition MRAffineXf.h:26
triangulations for all points, with easy access by VertId
Definition MRLocalTriangulations.h:51
flat map: I -> T
Definition MRBuffer.h:136
a ball = points surrounded by a sphere in arbitrary space with vector type V
Definition MRBall.h:15
Box given by its min- and max- corners.
Definition MRBox.h:27
mapping among elements of source point cloud, from which a part is taken, and target (this) point clo...
Definition MRCloudPartMapping.h:13
Cubic Bezier curve.
Definition MRBezier.h:16
options determining computation of distance from a point to a mesh
Definition MRDistanceToMeshOptions.h:14
Definition MREdgeLengthMesh.h:16
two edge-points (e.g. representing collision point of two edges)
Definition MREdgePoint.h:53
encodes a point on an edge of mesh or of polyline
Definition MREdgePoint.h:14
Represents a segment on one edge.
Definition MREdgePoint.h:64
Parameters structure for MR::fillHole Structure has some options to control MR::fillHole.
Definition MRMeshFillHole.h:26
Definition MRSurfacePath.h:20
settings defining regular grid, where each quadrangular cell is split on two triangles in one of two ...
Definition MRGridSettings.h:14
Definition MRIntersectionPrecomputes2.h:35
Definition MRIntersectionPrecomputes.h:117
Definition MRIteratorRange.h:13
a segment of straight dimensional line
Definition MRLineSegm.h:15
ObjectMeshData and additional information from mesh importer.
Definition MRLoadedMeshData.h:15
result of loading (e.g. from a file) as a number of objects
Definition MRLoadedObjects.h:36
Definition MRMapOrHashMap.h:19
Definition MRMatrix2.h:24
Definition MRMatrix3.h:24
Definition MRMatrix4.h:25
Definition MRMinMaxArg.h:49
Definition MRMeshIntersect.h:18
an object and its transformation to global space with other objects
Definition MRMeshOrPoints.h:109
Definition MRMeshProject.h:18
Definition MRMeshPart.h:15
Definition MRMeshTexture.h:13
Definition MRMeshTriPoint.h:26
Definition MRMinMaxArg.h:16
Definition MRMinMaxArg.h:82
this class is similar to T, but does not make default initialization of the fields for best performan...
Definition MRNoDefInit.h:14
Definition MRMeshFwd.h:97
mesh and its per-element attributes for ObjectMeshHolder
Definition MRObjectMeshData.h:17
Definition MRBuffer.h:144
Represents quadratic function f(x) = a*x*x + b*x + c.
Definition MRParabola.h:14
mapping among elements of source mesh, from which a part is taken, and target mesh
Definition MRPartMapping.h:13
represents full point cloud (if region is nullptr) or some portion of point cloud (if region pointer ...
Definition MRPointCloudPart.h:13
Definition MRPointCloud.h:17
a point located on some mesh's face
Definition MRPointOnFace.h:16
Definition MRPointOnObject.h:21
Definition MRPointsProject.h:15
Definition MRPolylineProject.h:15
Definition MRPolylineProject.h:73
Definition MRPolyline.h:18
Definition MRQuaternion.h:16
Definition MRRigidScaleXf3.h:15
Definition MRRigidXf3.h:16
determines how to save points/lines/mesh
Definition MRSaveSettings.h:20
encodes a point inside a line segment using relative distance in [0,1]
Definition MRSegmPoint.h:17
options determining computation of signed distance from a point to a mesh
Definition MRDistanceToMeshOptions.h:40
describes a number of local triangulations of some points (e.g. assigned to a thread)
Definition MRLocalTriangulations.h:43
Definition MRSymMatrix2.h:17
Definition MRSymMatrix3.h:18
Definition MRSymMatrix4.h:16
Definition MRTbbTaskArenaAndGroup.h:16
struct to determine transparent rendering mode
Definition MRRenderModelParameters.h:13
Definition MRTriMesh.h:16
encodes a point inside a triangle using barycentric coordinates
Definition MRTriPoint.h:19
Definition MRUnorientedTriangle.h:16
Definition MRVector2.h:29
Definition MRVector3.h:33
Definition MRVector4.h:26
Definition MRMeshFwd.h:785