Visual Computing Library
All Classes Functions Variables Typedefs Enumerations Friends Modules Pages Concepts
create.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_CREATE_H
24#define VCL_ALGORITHMS_CORE_POLYGON_CREATE_H
25
26#include <vclib/space/core/polygon.h>
27
28namespace vcl {
29
39template<Polygon2Concept PolygonType>
40PolygonType createCircle(uint n, typename PolygonType::ScalarType radius = 1.0)
41{
42 using ScalarType = typename PolygonType::ScalarType;
43 using PointType = typename PolygonType::PointType;
44
46 poly.reserve(n);
47
48 const ScalarType angleStep = 2 * M_PI / n;
49 for (uint i = 0; i < n; ++i) {
50 const ScalarType angle = i * angleStep;
51 const PointType p =
52 PointType(std::cos(angle), std::sin(angle)) * radius;
53 poly.pushBack(p);
54 }
55
56 return poly;
57}
58
59} // namespace vcl
60
61#endif // VCL_ALGORITHMS_CORE_POLYGON_CREATE_H
A class representing a line segment in n-dimensional space. The class is parameterized by a PointConc...
Definition segment.h:43
PolygonType createCircle(uint n, typename PolygonType::ScalarType radius=1.0)
Create a 2D circle polygon with n vertices and the given radius.
Definition create.h:40