Visual Computing Library
devel
Version:
Loading versions...
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/space/core.h>
27
28
namespace
vcl {
29
40
template
<Po
int
3IteratorConcept Iterator>
41
auto
project
(Iterator begin, Iterator end)
42
{
43
using
PointType = Iterator::value_type;
44
using
ScalarType = PointType::ScalarType;
45
46
Polygon2<ScalarType>
projectedPolygon
;
47
48
// Calculate the normal vector of the polygon and an orthonormal basis
49
// for the plane containing the polygon.
50
PointType normal =
Polygon3<ScalarType>::normal
(begin, end);
51
PointType u, v;
52
normal.orthoBase(u, v);
53
54
projectedPolygon
.reserve(std::distance(begin, end));
55
56
// Project each vertex onto the plane defined by the orthonormal basis.
57
for
(
auto
it
= begin;
it
!= end; ++
it
) {
58
ScalarType x = (*it).dot(u);
59
ScalarType y = (*it).dot(v);
60
projectedPolygon
.pushBack(
Point2<ScalarType>
(x, y));
61
}
62
63
return
projectedPolygon
;
64
}
65
76
template
<Range R>
77
auto
project
(R&& polygon)
requires
Point3Concept<std::ranges::range_value_t<R>
>
78
{
79
return
project
(polygon.begin(), polygon.end());
80
}
81
82
}
// namespace vcl
83
84
#endif
// VCL_ALGORITHMS_CORE_POLYGON_PROJECTION_H
vcl::Box
A class representing a box in N-dimensional space.
Definition
box.h:46
vcl::Point3Concept
A concept representing a 3D Point.
Definition
point.h:871
vcl::project
auto project(Iterator begin, Iterator end)
Project a 3D polygon onto a plane, and return the 2D polygon.
Definition
projection.h:41
vclib
core
include
vclib
algorithms
core
polygon
projection.h
Generated by
1.9.8