19 virtual void findProjections( std::vector<MeshProjectionResult>& result,
const std::vector<Vector3f>& points,
20 const AffineXf3f* worldXf =
nullptr,
const AffineXf3f* worldRefXf =
nullptr,
21 float upDistLimitSq = FLT_MAX,
float loDistLimitSq = 0.0f ) = 0;
38 const AffineXf3f*
refXf =
nullptr;
41 const AffineXf3f*
xf =
nullptr;
49 const VertCoords & testPoints,
const VertBitSet * validTestPoints = {},
50 const MeshProjectionParameters & params = {},
51 IPointsToMeshProjector * projector = {} );
60 IPointsToMeshProjector * projector = {} );
65 const Mesh* mesh_{
nullptr };
79 const AffineXf3f* objXf,
const AffineXf3f* refObjXf,
80 float upDistLimitSq,
float loDistLimitSq )
override;
#define MRMESH_API
Definition MRMesh/MRMeshFwd.h:79
#define MRMESH_CLASS
Definition MRMesh/MRMeshFwd.h:83
Abstract class, computes the closest point on mesh to each of given points. Pure virtual functions mu...
Definition MRPointsToMeshProjector.h:13
virtual size_t projectionsHeapBytes(size_t numProjections) const =0
Returns amount of memory needed to compute projections.
virtual void updateMeshData(const Mesh *mesh)=0
Updates all data related to the referencing mesh.
virtual ~IPointsToMeshProjector()=default
virtual void findProjections(std::vector< MeshProjectionResult > &result, const std::vector< Vector3f > &points, const AffineXf3f *worldXf=nullptr, const AffineXf3f *worldRefXf=nullptr, float upDistLimitSq=FLT_MAX, float loDistLimitSq=0.0f)=0
Computes the closest point on mesh to each of given points.
Computes the closest point on mesh to each of given points on CPU.
Definition MRPointsToMeshProjector.h:64
virtual MRMESH_API size_t projectionsHeapBytes(size_t numProjections) const override
Returns amount of additional memory needed to compute projections.
virtual MRMESH_API void findProjections(std::vector< MeshProjectionResult > &result, const std::vector< Vector3f > &points, const AffineXf3f *objXf, const AffineXf3f *refObjXf, float upDistLimitSq, float loDistLimitSq) override
Computes the closest point on mesh to each of given points.
virtual MRMESH_API void updateMeshData(const Mesh *mesh) override
update all data related to the referencing mesh
MRMESH_API VertScalars findSignedDistances(const Mesh &refMesh, const VertCoords &testPoints, const VertBitSet *validTestPoints={}, const MeshProjectionParameters ¶ms={}, IPointsToMeshProjector *projector={})
if projector is not given then CPU's computations will be used
Definition MRPointsToMeshProjector.h:28
float loDistLimitSq
Definition MRPointsToMeshProjector.h:31
const AffineXf3f * refXf
optional reference mesh to world transformation
Definition MRPointsToMeshProjector.h:38
const AffineXf3f * xf
optional test points to world transformation
Definition MRPointsToMeshProjector.h:41
float upDistLimitSq
Definition MRPointsToMeshProjector.h:35
Definition MRMesh/MRMesh.h:23