MeshLib C++ Docs
Loading...
Searching...
No Matches
MRContour.h
Go to the documentation of this file.
1#pragma once
2
3#include "MRPch/MRBindingMacros.h"
4#include "MRMeshFwd.h"
5#include "MRVector3.h"
6
7namespace MR
8{
9
13
16template<typename T, typename R = T>
17R calcOrientedArea( const Contour2<T> & contour )
18{
19 if ( contour.size() < 3 )
20 return 0;
21
22 R area = 0;
23 Vector2<R> p0{ contour[0] };
24
25 for ( int i = 2; i < contour.size(); ++i )
26 {
27 Vector2<R> p1{ contour[i - 1] };
28 Vector2<R> p2{ contour[i] };
29 area += cross( p2 - p0, p1 - p0 );
30 }
31
32 return R(0.5) * area;
33}
34
38template<typename T, typename R = T>
40{
41 if ( contour.size() < 3 )
42 return {};
43
45 Vector3<R> p0{ contour[0] };
46
47 for ( int i = 2; i < contour.size(); ++i )
48 {
49 Vector3<R> p1{ contour[i - 1] };
50 Vector3<R> p2{ contour[i] };
51 area += cross( p1 - p0, p2 - p0 );
52 }
53
54 return R(0.5) * area;
55}
56
59template<typename V, typename R = typename V::ValueType>
60R calcLength( const Contour<V>& contour )
61{
62 R l = R( 0 );
63 for ( int i = 1; i < contour.size(); ++i )
64 l += R( ( contour[i] - contour[i - 1] ).length() );
65 return l;
66}
67
69template<typename To, typename From>
70To copyContour( const From & from )
71{
72 To res;
73 res.reserve( from.size() );
74 for ( const auto & p : from )
75 res.emplace_back( p );
76 return res;
77}
78
80template<typename To, typename From>
81To copyContours( const From & from )
82{
83 To res;
84 res.reserve( from.size() );
85 for ( const auto & c : from )
86 res.push_back( copyContour<typename To::value_type>( c ) );
87 return res;
88}
89
91
92// Instantiate the templates when generating bindings.
93MR_BIND_TEMPLATE( float calcOrientedArea( const Contour2<float> & contour ) )
94MR_BIND_TEMPLATE( double calcOrientedArea( const Contour2<double> & contour ) )
95MR_BIND_TEMPLATE( float calcLength( const Contour2<float>& contour ) )
96MR_BIND_TEMPLATE( double calcLength( const Contour2<double>& contour ) )
97MR_BIND_TEMPLATE( float calcLength( const Contour3<float>& contour ) )
98MR_BIND_TEMPLATE( double calcLength( const Contour3<double>& contour ) )
99MR_BIND_TEMPLATE( Vector3<float> calcOrientedArea( const Contour3<float> & contour ) )
100MR_BIND_TEMPLATE( Vector3<double> calcOrientedArea( const Contour3<double> & contour ) )
101MR_BIND_TEMPLATE( Contour2<float> copyContour( const Contour2<double> & from ) )
102MR_BIND_TEMPLATE( Contour3<float> copyContour( const Contour3<double> & from ) )
103MR_BIND_TEMPLATE( Contour2<double> copyContour( const Contour2<float> & from ) )
104MR_BIND_TEMPLATE( Contour3<double> copyContour( const Contour3<float> & from ) )
105
106} // namespace MR
length
Definition MRObjectDimensionsEnum.h:14
Contour
Definition MRObjectLabel.h:16
R calcLength(const Contour< V > &contour)
Definition MRContour.h:60
To copyContours(const From &from)
copy double-contours to float-contours, or vice versa
Definition MRContour.h:81
R calcOrientedArea(const Contour2< T > &contour)
Definition MRContour.h:17
To copyContour(const From &from)
copy double-contour to float-contour, or vice versa
Definition MRContour.h:70
Contour< Vector2< T > > Contour2
Definition MRMesh/MRMeshFwd.h:294
Contour< Vector3< T > > Contour3
Definition MRMesh/MRMeshFwd.h:295
MRMESH_CLASS Vector3
Definition MRMesh/MRMeshFwd.h:159
T area(const Vector3< T > &p, const Vector3< T > &q, const Vector3< T > &r)
computes twice the area of given triangle
Definition MRTriMath.h:160
Definition MRVector2.h:18
Definition MRMesh/MRVector3.h:19