【ros笔记】ros和pcl点云类型相互转换


前言

记录一下PCL点云格式与ROS点云格式互相转换的过程。
ROS 点云格式PCL点云格式
sensor_msgs::LaserScanpcl::PointCloud<pcl::PointXYZ>
sensor_msgs::PointCloud2pcl::PointCloud<pcl::PointXYZ>

一、ROS点云类型概述

  1. 类型 sensor_msgs::LaserScan 在ros中一般用于二维点云存储,大部分单线激光雷达输出的就是这种格式,在rviz下显示如下:
    在这里插入图片描述

  2. 类型 sensor_msgs::PointCloud2 在ros中可以展示二维点云,也可以展示三维点云。

二、PCL点云类型概述

  1. 类型 pcl::PointCloud<pcl::PointXYZ> 与 类型 pcl::PCLPointCloud2 我的理解是后者是PCL官方推出来想取代前者的。
    有兴趣去官网看看吧:
    http://pointclouds.org/documentation/structpcl_1_1_p_c_l_point_cloud2.html

三、转换实现

1. sensor_msgs::LaserScan转到sensor_msgs::PointCloud2

这是两个ros类型的相互转换,这里主要用到projectLaser这个方法。

转换代码如下:

  //输入的 ros LaserScan 类型
 sensor_msgs::LaserScan::ConstPtr& msg;
 laser_geometry::LaserProjection t_projectoir;
 //输出的ros pointcloud2 类型
 sensor_msgs::PointCloud2 t_cloud;
 //转换到 ros pointcloud2 类型
 t_projectoir.projectLaser(*msg,t_cloud);

2. sensor_msgs::PointCloud2转到 pcl::PointCloud&ltpcl::PointXYZ>

这是ros到pcl类型的转换,用到fromROSMsg方法。

转换代码如下:

 //输入的ros pointcloud2 类型
 sensor_msgs::PointCloud2 t_cloud;
 //输出的pcl 类型
 pcl::PointCloud<pcl::PointXYZ> t_pclCloud;
 pcl::fromROSMsg(t_cloud,t_pclCloud);

3. pcl::PointCloud&ltpcl::PointXYZ>转到sensor_msgs::PointCloud

这是pcl 到ros类型转换,用到toROSMsg方法。(这边转成ros类型后可以publish出去,然后在rviz中就可以看了)

转换代码如下:

 //输入的pcl 类型
 pcl::PointCloud<pcl::PointXYZ> t_pclCloud;
 //输出的ros 类型
 sensor_msgs::PointCloud2 t_rosCloud;
 pcl::toROSMsg(t_pclCloud,t_rosCloud);
 //发布出去	
 //t_scanPub.publish(t_rosCloud);

总结

这里只是记录了最简单的转换,在ros转到pcl时如果有坐标上的偏差还可以用 transformLaserScanToPointCloud 方法,后面将逐步完善。

  • 9
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
ROS中,可以使用PointCloud2消息类型来表示点云数据。要将PCL点云转换ROS点云,可以按照以下步骤操作: 1. 创建一个PointCloud2消息对象,设置其header和fields属性。Header属性包含一些元数据,如时间戳、坐标系等,而Fields属性定义了每个点的数据类型和名称。 2. 将PCL点云数据转换为一个ROS消息中的二进制数据数组。这可以通过将PCL点云数据复制到ROS消息中的二进制数据数组中来完成。 3. 将二进制数据数组设置为PointCloud2消息对象的data属性。 4. 将PointCloud2消息对象发布到ROS话题中,以便其他节点可以接收和处理该点云数据。 下面是一个示例代码,可以将一个PCL点云转换ROS点云并发布到ROS话题中: ``` #include <ros/ros.h> #include <pcl_conversions/pcl_conversions.h> #include <sensor_msgs/PointCloud2.h> #include <pcl/point_cloud.h> #include <pcl/point_types.h> int main(int argc, char **argv) { // 初始化ROS节点 ros::init(argc, argv, "pcl_to_ros_node"); ros::NodeHandle nh; // 创建一个PCL点云对象 pcl::PointCloud<pcl::PointXYZ> pcl_cloud; // 填充点云数据(省略) // 创建一个ROS消息对象 sensor_msgs::PointCloud2 ros_cloud; // 将PCL点云数据转换ROS消息中的二进制数据数组 pcl::toROSMsg(pcl_cloud, ros_cloud); // 设置ROS消息对象的header和fields属性 ros_cloud.header.frame_id = "pcl_frame"; ros_cloud.header.stamp = ros::Time::now(); ros_cloud.fields.resize(3); ros_cloud.fields[0].name = "x"; ros_cloud.fields[0].offset = 0; ros_cloud.fields[0].datatype = sensor_msgs::PointField::FLOAT32; ros_cloud.fields[0].count = 1; ros_cloud.fields[1].name = "y"; ros_cloud.fields[1].offset = 4; ros_cloud.fields[1].datatype = sensor_msgs::PointField::FLOAT32; ros_cloud.fields[1].count = 1; ros_cloud.fields[2].name = "z"; ros_cloud.fields[2].offset = 8; ros_cloud.fields[2].datatype = sensor_msgs::PointField::FLOAT32; ros_cloud.fields[2].count = 1; // 设置ROS消息对象的data属性 ros_cloud.data = std::vector<uint8_t>(ros_cloud.point_step * pcl_cloud.size()); memcpy(&ros_cloud.data[0], pcl_cloud.points.data(), ros_cloud.data.size()); // 创建一个ROS话题发布者,并发布ROS消息对象 ros::Publisher pub = nh.advertise<sensor_msgs::PointCloud2>("ros_cloud_topic", 1); pub.publish(ros_cloud); // 进入ROS循环 ros::spin(); return 0; } ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值