菜单 学习猿地 - LMONKEY

VIP

开通学习猿地VIP

尊享10项VIP特权 持续新增

知识通关挑战

打卡带练!告别无效练习

接私单赚外块

VIP优先接,累计金额超百万

学习猿地私房课免费学

大厂实战课仅对VIP开放

你的一对一导师

每月可免费咨询大牛30次

领取更多软件工程师实用特权

入驻
473
0

PCL 注意事项

原创
05/13 14:22
阅读数 3944

pcl::transformPointCloud 函数使用

method 1

#include <pcl/common/transforms.h>

pcl::PointCloud<pcl::PointXYZRGB>::Ptr cloudsWorld(new pcl::PointCloud<pcl::PointXYZRGB>);

Eigen::AngleAxisd zAngleAxis(posRet.theta, Eigen::Vector3d(0, 0, 1));
Eigen::Quaterniond q(zAngleAxis);
Eigen::Isometry3d pose(q);
pose(0, 3) = pos.x_pos; 
pose(1, 3) = pos.y_pos; 
pose(2, 3) = 0;

pcl::transformPointCloud(*clouds, *cloudsWorld, pose.matrix());

method 2

#include <pcl/common/transforms.h>

pcl::PointCloud<pcl::PointXYZRGB>::Ptr cloudsWorld(new pcl::PointCloud<pcl::PointXYZRGB>);

Eigen::Affine3f pose = Eigen::Affine3f::Identity();
pose.translation() << pos.x_pos, pos.y_pos, 0.0;
pose.rotate(Eigen::AngleAxisf(pos.theta, Eigen::Vector3f::UnitZ()));
pcl::transformPointCloud(*clouds, *cloudsWorld, pose);

pcl::PoiintCloudpcl::Point::Ptr

如果此类的sensor_origin_/orientation被配置,PCLViewer在显示时候会做相应的旋转和平移

发表评论

0/200
473 点赞
0 评论
收藏