models.h
Go to the documentation of this file.
1/*
2 * This file is part of ArmarX.
3 *
4 * ArmarX is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 *
8 * ArmarX is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 *
16 * @author Fabian Reister ( fabian dot reister at kit dot edu )
17 * @date 2021
18 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
19 * GNU General Public License
20 */
21
22#pragma once
23
24#include <Eigen/Core>
25
26#include "wykobi_types.h"
27#include <wykobi.hpp>
28
30{
31
32 struct Model
33 {
34 Eigen::Vector3f center;
36 };
37
38 inline Model
39 makeCube(const Eigen::Vector2f& position, const float width)
40 {
41 const float w2 = width / 2;
42
43 std::vector<::wykobi::point2d<float>> pointList;
44 pointList.push_back(::wykobi::make_point(position.x() + w2, position.y() + w2));
45 pointList.push_back(::wykobi::make_point(position.x() - w2, position.y() + w2));
46 pointList.push_back(::wykobi::make_point(position.x() - w2, position.y() - w2));
47 pointList.push_back(::wykobi::make_point(position.x() + w2, position.y() - w2));
48
49 return Model({.center = Eigen::Vector3f{position.x(), position.y(), 0.F},
50 .polygon = ::wykobi::make_polygon(pointList)});
51 }
52
53} // namespace armarx::wykobi
::wykobi::polygon< float, 2 > Polygon
Model makeCube(const Eigen::Vector2f &position, const float width)
Definition models.h:39
Eigen::Vector3f center
Definition models.h:34
wykobi::Polygon polygon
Definition models.h:35