点云从二维的/scan转换到三维/PointCloud2

点云从二维到三维的转换,话题由/scan到/PointCloud2

由于有的激光雷达扫描得到的点云格式是二维的,其话题类型为/scan,不能直接转换为pcd的文件,所以这里可以转化为三维格式,话题转换为/PointCloud2,这样就可以直接对点云进行处理。

1.录制bag文件

rosbag record /scan -O classroom.bag

(这里的/scan是发布数据的主题,-O后面是保存的包的名字)

2.创建python文件

在一个新的终端中输入如下命令:

cd ros_ws/src
catkin_create_pkg lasertopc rospy sensor_msgs laser_geometry

这会创建一个ROS的package,然后再进入到lasertopc文件夹的src中,创建python文件,名字为laser_to_pc.py,将下面的代码复制进去:

#!/usr/bin/env python

import rospy
from sensor_msgs.msg import PointCloud2 as pc2
from sensor_msgs.msg import LaserScan
from laser_geometry import LaserProjection

class Laser2PC():
    def __init__(self):
        self.laserProj = LaserProjection()
        self.pcPub = rospy.Publisher("/laserPointCloud", pc2, queue_size=1)
        self.laserSub = rospy.Subscriber("/scan", LaserScan, self.laserCallback) 

    def laserCallback(self,data):

        cloud_out = self.laserProj.projectLaser(data)

        self.pcPub.publish(cloud_out)

if __name__ == '__main__':
    rospy.init_node("laser2PointCloud")
    l2pc = Laser2PC()
    rospy.spin()

3.运行

1.首先对工作空间进行编译:

cd ros_ws
catkin_make

2.运行python文件:

rosrun lasertopc laser_to_pc.py

3.播放录制好的bag:
进入录制的bag包所在的路径

rosbag play classroom.bag (记得改名字)

4.录制转换好的bag文件:
注意:这条命令和上一条最好同时执行,在上一条命令播放时这里就要开始录制,如果这里太慢可能会播放完了才录制,可能录不到东西。

rosbag record /laserPointCloud -O xxx.bag

这里的/laserPointCloud是python文件中定义的话题名
5.将bag文件转换为pcd文件

rosrun pcl_ros bag_to_pcd xxx.bag (上一步的bag) /laserPointCloud pcdpcd (这里是存放pcd文件的文件夹)

这样就完成了从/scan 的bag文件转换为pcd文件

4.总结

这个方法就是创建了一个可执行的python程序,该程序创建两个节点,一个负责接收/scan的数据,一个负责发布/PointCloud2的数据,所以在这个程序运行时,创建一个终端来播放转换之前的bag数据,另一个终端同时来录制转换好的bag数据,这样转换好之后就可以利用pcl自带的工具来将bag转换为pcd文件。

参考博客

在ROS 2中,将点云数据转换二维栅格地图通常需要借助于相关的传感器建图库,如`map_server`和`nav2_map_common`等工具。以下是基本步骤: 1. **获取点云数据**:首先,你需要从激光雷达或其他三维感知设备收集实时的点云数据。这通常通过`sensor_msgs/LaserScan`或`sensor_msgs/PointCloud2`消息来完成。 2. **点云处理**:使用像`rviz`这样的可视化工具,或者编写专门的节点来清理、滤波和组织点云,去除无效数据并将其转换为易于分析的数据结构。 3. **转换到栅格地图**:利用ROS包`nav2_map_common`中的函数,特别是`tf2_ros::Buffer`和`grid_map_2d_ros`,可以将点云转换二维栅格地图。例如,你可以创建一个`GridMap`实例,并设置其分辨率和范围,然后将点云投影到这个网格上。 ```cpp #include <grid_map_ros/GridMapRosConverter.h> GridMap grid_map; ros::NodeHandle nh; tf2_ros::Buffer tf_buffer; // 确定网格大小和坐标系变换 grid_map.setResolution(resolution); tf::Transform transform = ...; // 获取从激光雷达到世界坐标系的转换 grid_map_ros::transformPointCloud(grid_map, laser_scan_msg, transform, grid_map); ``` 4. **保存和显示**:最后,你可以将生成的栅格地图发布到`grid_map_msgs/msg/GridMap`话题上,以便其他系统消费或用`rviz`等工具查看。 5. **注意事项**:栅格地图的构建可能会消耗大量内存和计算资源,因此优化设置(如调整分辨率、帧率)至关重要。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值