bag主题是laserscan时无法转化为pcd的方法

可视化bag部分

首先使用rosbag info 查看bag包的信息

可以看到topics是/scan_2,types是sensor_msgs/LaserScan,

然后使用rviz可视化

第一次可视化不了,因为fixed Frame里默认是map无法选择,这里得先rosbag play *。bag

然后运行下面的代码

rostopic echo /scan_2 | grep frame_id

来监听frame_id,我的是lidar_back

然后就可以在rviz中可视化了

add一个 laserscan对象,topic改成/scan_2,不过这是我的,每个人的可能不太一样

转化部分

首先得写一个节点laser2PC,

这是我看的别人的icon-default.png?t=M4ADhttps://blog.csdn.net/Laikh/article/details/104743308?ops_request_misc=&request_id=&biz_id=102&utm_term=laser2pcd&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-3-104743308.142^v10^pc_search_result_control_group,157^v4^control&spm=1018.2226.3001.4187laser2PC.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) #topic名称可能不同,请根据实际情况进行修改。可以在终端输入rostopic list查看

    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()

cmakelists.txt加入这个配置一下,会ros的应该都知道

catkin_install_python(PROGRAMS scripts/laser2pc.py
  DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
)

然后就运行就行

首先roscore

然后rosbag play *.bag

再在工作空间rosrun laser2PC节点

最后rosbag record -a

最好稍等一会在结束record进程,不然会是active的文件

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当您编写C++代码来录制Laserscan点云bag文件,可以使用ROS(Robot Operating System)来处理点云数据。以下是一个简单的示例代码,用于录制Laserscan点云并将其保存为bag文件: ```cpp #include <ros/ros.h> #include <sensor_msgs/LaserScan.h> #include <rosbag/bag.h> #include <rosbag/view.h> int main(int argc, char** argv) { // 初始化ROS节点 ros::init(argc, argv, "laser_scan_recorder"); ros::NodeHandle nh; // 创建ROS bag文件 rosbag::Bag bag; bag.open("laser_scan_bag.bag", rosbag::bagmode::Write); // 创建Laserscan消息 sensor_msgs::LaserScan scan_msg; // 设置Laserscan消息的参数 scan_msg.header.frame_id = "laser_frame"; scan_msg.angle_min = -M_PI/2; // 最小角度 scan_msg.angle_max = M_PI/2; // 最大角度 scan_msg.angle_increment = M_PI/180; // 角度增量 scan_msg.range_min = 0.0; // 最小测距范围 scan_msg.range_max = 10.0; // 最大测距范围 // 模拟生成一些点云数据 for (float angle = scan_msg.angle_min; angle <= scan_msg.angle_max; angle += scan_msg.angle_increment) { float range = 5.0; // 模拟距离为5.0米 scan_msg.ranges.push_back(range); } // 将Laserscan消息写入bag文件 bag.write("laser_scan_topic", ros::Time::now(), scan_msg); // 关闭bag文件 bag.close(); return 0; } ``` 注意:上述代码是一个简单示例,仅用于演示如何录制Laserscan点云并将其保存为bag文件。您需要根据您的实际需求进行适当的修改和扩展。确保在编译和运行代码之前安装了ROS和相关的依赖项。 希望这个示例对您有帮助!如有任何其他问题,请随提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值