MeshLib C++ Docs
Loading...
Searching...
No Matches
MRPrecisePredicates3.h
Go to the documentation of this file.
1#pragma once
2
3#include "MRVector3.h"
4#include "MRId.h"
5#include <array>
6#include <optional>
7
8namespace MR
9{
10
13
16MRMESH_API bool orient3d( const Vector3i & a, const Vector3i & b, const Vector3i & c );
17
20inline bool orient3d( const Vector3i & a, const Vector3i & b, const Vector3i & c, const Vector3i & d )
21 { return orient3d( a - d, b - d, c - d ); }
22
23struct PreciseVertCoords
24{
25 VertId id;
26 Vector3i pt;
27};
28
30MRMESH_API bool orient3d( const std::array<PreciseVertCoords, 4> & vs );
32
34{
35 bool doIntersect = false;
36 bool dIsLeftFromABC = false;
37
38 explicit operator bool() const { return doIntersect; }
39};
40
44 const std::array<PreciseVertCoords, 5> & vs );
45
50[[nodiscard]] MRMESH_API bool segmentIntersectionOrder( const std::array<PreciseVertCoords, 8> & vs );
51
53using ConvertToIntVector = std::function<Vector3i( const Vector3f& )>;
55using ConvertToFloatVector = std::function<Vector3f( const Vector3i& )>;
58{
59 ConvertToIntVector toInt{};
60 ConvertToFloatVector toFloat{};
61};
62
64MRMESH_API ConvertToIntVector getToIntConverter( const Box3d& box );
66MRMESH_API ConvertToFloatVector getToFloatConverter( const Box3d& box );
67
70[[nodiscard]] MRMESH_API std::optional<Vector3i> findTwoSegmentsIntersection( const Vector3i& ai, const Vector3i& bi, const Vector3i& ci, const Vector3i& di );
71
75 const Vector3f& a, const Vector3f& b, const Vector3f& c,
76 const Vector3f& d, const Vector3f& e,
77 CoordinateConverters converters );
78
80
81}
#define MRMESH_API
Definition MRMeshFwd.h:80
Definition MRPrecisePredicates3.h:58
Definition MRPrecisePredicates3.h:24
new unsafe ref MR.VertId id
Definition MRPrecisePredicates3.h:34
MRMESH_API TriangleSegmentIntersectResult doTriangleSegmentIntersect(const std::array< PreciseVertCoords, 5 > &vs)
MRMESH_API ConvertToFloatVector getToFloatConverter(const Box3d &box)
creates converter from Vector3i to Vector3f in Box range (int diapason is mapped to box range)
MRMESH_API Vector3f findTriangleSegmentIntersectionPrecise(const Vector3f &a, const Vector3f &b, const Vector3f &c, const Vector3f &d, const Vector3f &e, CoordinateConverters converters)
MRMESH_API ConvertToIntVector getToIntConverter(const Box3d &box)
creates converter from Vector3f to Vector3i in Box range (int diapason is mapped to box range)
MRMESH_API std::optional< Vector3i > findTwoSegmentsIntersection(const Vector3i &ai, const Vector3i &bi, const Vector3i &ci, const Vector3i &di)
MRMESH_API bool orient3d(const Vector3i &a, const Vector3i &b, const Vector3i &c)
Definition MRCameraOrientationPlugin.h:8
MRMESH_API bool segmentIntersectionOrder(const std::array< PreciseVertCoords2, 6 > &vs)