opencv_pcl.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 <pcl/point_cloud.h>
27
#include <pcl/point_types.h>
28
29
#include <opencv2/core/types.hpp>
30
31
namespace
armarx::conversions
32
{
33
34
inline
cv::Point2f
35
pcl2cv
(
const
pcl::PointXY& pt)
36
{
37
return
cv::Point2f{pt.x, pt.y};
38
}
39
40
inline
cv::Point3f
41
pcl2cv
(
const
pcl::PointXYZ& pt)
42
{
43
return
cv::Point3f{pt.x, pt.y, pt.z};
44
}
45
46
template
<
typename
Po
int
T,
typename
CvT = decltype(pcl2cv(Po
int
T()))>
47
auto
48
pcl2cv
(
const
pcl::PointCloud<PointT>& pointCloud)
49
{
50
std::vector<CvT> v;
51
v.reserve(pointCloud.points.size());
52
53
std::transform(pointCloud.points.begin(),
54
pointCloud.points.end(),
55
std::back_inserter(v),
56
static_cast<
CvT (*)(
const
PointT
&)
>
(
pcl2cv
));
57
58
return
v;
59
}
60
61
}
// namespace armarx::conversions
armarx::conversions
Definition
eigen.cpp:8
armarx::conversions::pcl2cv
cv::Point2f pcl2cv(const pcl::PointXY &pt)
Definition
opencv_pcl.h:35
armarx::PointT
pcl::PointXYZRGBL PointT
Definition
Common.h:30
armarx
navigation
components
laser_scanner_feature_extraction
conversions
opencv_pcl.h
Generated by
1.13.2