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
31namespace 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 PointT, typename CvT = decltype(pcl2cv(PointT()))>
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
cv::Point2f pcl2cv(const pcl::PointXY &pt)
Definition opencv_pcl.h:35
pcl::PointXYZRGBL PointT
Definition Common.h:30