ROS下PCL点云读取显示

前提:
安装clion,clion ROS配置,loam下载使用,数据集下载,velodyne_ros下载,
load_map:
读取地图pcd文件,pcl::visualize显示和转换toROSMsg发布publish topic用rviz显示

创建功能包

catkin_create_pkg learn_loam roscpp rospy std_msgs sensor_msgs pcl_ros pcl_conversion
catkin_make

需要修改CMakeList.txt和package.xml

在工作空间启动clion

sh /opt/clion-2019.2.1/bin/clion.sh

打开project,选中CMakeList.txt

添加库文件支持
find_package(PCL REQUIRED)

catkin_package(
  INCLUDE_DIRS include
  CATKIN_DEPENDS pcl_conversions pcl_ros roscpp rospy sensor_msgs std_msgs
  DEPENDS  PCL
)

include_directories(
 include
  ${catkin_INCLUDE_DIRS}
        ${PCL_INCLUDE_DIRS}
)
#可执行文件和链接库
add_executable(load_map src/load_map.cpp)
target_link_libraries(load_map ${catkin_LIBRARIES} ${PCL_LIBRARIES})

创建源文件load_map.cpp,读取地图PCD,PCL显示,转换ROS消息发布topic

#include <ros/ros.h>
#include <sensor_msgs/PointCloud2.h>
#include <pcl/point_cloud.h>
#include <pcl/point_types.h>
#include <pcl/io/pcd_io.h>
#include <pcl_conversions/pcl_conversions.h>
#include <pcl/visualization/pcl_visualizer.h>
#include <iostream>

//pcl显示点云
void visualizer_one_points(pcl::PointCloud<pcl::PointXYZ>::Ptr cloud,std::string name)
{
    boost::shared_ptr<pcl::visualization::PCLVisualizer> viewer(new pcl::visualization::PCLVisualizer(name));

    viewer->setBackgroundColor(0,0,0);
    pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> cloud_color(cloud,0,0,255);
    viewer->addPointCloud(cloud,cloud_color,name);

    viewer->spinOnce(100);			//while(!viewer->wasStopped())会卡在这

}

int main(int argc,char** argv)
{
    ros::init(argc,argv,"load_map");
    ros::NodeHandle nh;

    pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_map(new pcl::PointCloud<pcl::PointXYZ>);
    sensor_msgs::PointCloud2 cloud_map_msg;

    ros::Time begin=ros::Time::now();		//计算读取时间,耗时比较长,但是发布耗时小于1s,发布频率可以为1
    ROS_INFO("begin:%f",begin.toSec());

    pcl::io::loadPCDFile("/home/zhangxu/catkin_ws/Lidar_rawdata/segmap/drive27_target_map.pcd",*cloud_map);
    visualizer_one_points(cloud_map,"map");

    ros::Time load=ros::Time::now();
    ROS_INFO("load-begin=%f -%f=%f",load.toSec(),begin.toSec(),load.toSec()-begin.toSec());

    pcl::toROSMsg(*cloud_map,cloud_map_msg);		//转成ros消息
    cloud_map_msg.header.frame_id="map";		//rviz显示需要fixed_frame

    ros::Publisher map_pub=nh.advertise<sensor_msgs::PointCloud2>("load_map",1);

    ros::Rate loop_rate(1);
    int i=0;
    while(ros::ok())
    {
        map_pub.publish(cloud_map_msg);
        ROS_INFO("MAP Publish %d",++i);
        ros::spinOnce();
        loop_rate.sleep();
    }

    return 0;
}
sensor_msgs::PointCloud2消息格式

rosmsg show sensor_msgs/PointCloud2

std_msgs/Header header
 uint32 seq
 time stamp
 string frame_id
uint32 height
uint32 width
sensor_msgs/PointField[] fields
 uint8 INT8=1
 uint8 UINT8=2
 uint8 INT16=3
 uint8 UINT16=4
 uint8 INT32=5
 uint8 UINT32=6
 uint8 FLOAT32=7
 uint8 FLOAT64=8
 string name
 uint32 offset
 uint8 datatype
 uint32 count
bool is_bigendian
uint32 point_step
uint32 row_step
uint8[] data
bool is_dense

PCL点云显示
 	boost::shared_ptr<pcl::visualization::PCLVisualizer> viewer(new pcl::visualization::PCLVisualizer(name));
    viewer->setBackgroundColor(0,0,0);
    pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> cloud_color(cloud,0,0,255);
    viewer->addPointCloud(cloud,cloud_color,name);
rviz显示

在这里插入图片描述

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值