Visual Computing Library
Loading...
Searching...
No Matches
projection.h
1
/*****************************************************************************
2
* VCLib *
3
* Visual Computing Library *
4
* *
5
* Copyright(C) 2021-2025 *
6
* Visual Computing Lab *
7
* ISTI - Italian National Research Council *
8
* *
9
* All rights reserved. *
10
* *
11
* This program is free software; you can redistribute it and/or modify *
12
* it under the terms of the Mozilla Public License Version 2.0 as published *
13
* by the Mozilla Foundation; either version 2 of the License, or *
14
* (at your option) any later version. *
15
* *
16
* This program is distributed in the hope that it will be useful, *
17
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
18
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
19
* Mozilla Public License Version 2.0 *
20
* (https://www.mozilla.org/en-US/MPL/2.0/) for more details. *
21
****************************************************************************/
22
23
#ifndef VCL_ALGORITHMS_CORE_POLYGON_PROJECTION_H
24
#define VCL_ALGORITHMS_CORE_POLYGON_PROJECTION_H
25
26
#include <vclib/concepts/space/point.h>
27
#include <vclib/space/core/polygon.h>
28
29
namespace
vcl {
30
41
template
<Po
int
3IteratorConcept Iterator>
42
auto
project
(Iterator begin, Iterator end)
43
{
44
using
PointType = Iterator::value_type;
45
using
ScalarType = PointType::ScalarType;
46
47
Polygon2<ScalarType>
projectedPolygon
;
48
49
// Calculate the normal vector of the polygon and an orthonormal basis
50
// for the plane containing the polygon.
51
PointType normal =
Polygon3<ScalarType>::normal
(begin, end);
52
PointType u, v;
53
normal.orthoBase(u, v);
54
55
projectedPolygon
.reserve(std::distance(begin, end));
56
57
// Project each vertex onto the plane defined by the orthonormal basis.
58
for
(
auto
it
= begin;
it
!= end; ++
it
) {
59
ScalarType x = (*it).dot(u);
60
ScalarType y = (*it).dot(v);
61
projectedPolygon
.pushBack(
Point2<ScalarType>
(x, y));
62
}
63
64
return
projectedPolygon
;
65
}
66
77
template
<Range R>
78
auto
project
(R&& polygon)
requires
Point3Concept<std::ranges::range_value_t<R>
>
79
{
80
return
project
(polygon.begin(), polygon.end());
81
}
82
83
}
// namespace vcl
84
85
#endif
// VCL_ALGORITHMS_CORE_POLYGON_PROJECTION_H
vcl::Segment
A class representing a line segment in n-dimensional space. The class is parameterized by a PointConc...
Definition
segment.h:43
vcl::Point3Concept
Concept for points in three-dimensional space.
Definition
point.h:130
vcl::project
auto project(Iterator begin, Iterator end)
Project a 3D polygon onto a plane, and return the 2D polygon.
Definition
projection.h:42
vclib
core
include
vclib
algorithms
core
polygon
projection.h
Generated by
1.9.8