可视化pointcloud

时间:2016-10-28 09:36:31

标签: opencv ros point-cloud-library point-clouds

我在找到的视差图像上有来自gpu :: reprojectImageTo3D的3D点。我现在想要显示这个点云。

如何将找到的pointcloud从OpenCV转换为sensor_msgs/PointCloud2

我不需要发布pointcloud这只是用于调试可视化。是否可以像节点中的图像一样显示它?例如使用pcl?这将是最佳的,因为我的设备可能无法与RViz(基于在线阅读)表现良好。

1 个答案:

答案 0 :(得分:4)

我最好的猜测是这样做,只是遍历cv::mat并插入pcl转换为msg,因为我没有找到任何直接做的事情。

#include <ros/ros.h>
// point cloud headers
#include <pcl/point_cloud.h>
//Header which contain PCL to ROS and ROS to PCL conversion functions
#include <pcl_conversions/pcl_conversions.h>
//sensor_msgs header for point cloud2
#include <sensor_msgs/PointCloud2.h>
main (int argc, char **argv)
{
    ros::init (argc, argv, "pcl_create");
    ROS_INFO("Started PCL publishing node");
    ros::NodeHandle nh;
    //Creating publisher object for point cloud
    ros::Publisher pcl_pub = nh.advertise<sensor_msgs::PointCloud2> ("pcl_output", 1);
    //Creating a cloud object
    pcl::PointCloud<pcl::PointXYZ> cloud;
    //Creating a sensor_msg of point cloud
    sensor_msgs::PointCloud2 output;
    //Insert cloud data
    cloud.width  = 50000;
    cloud.height = 2;
    cloud.points.resize(cloud.width * cloud.height);
    //Insert random points on the clouds
    for (size_t i = 0; i < cloud.points.size (); ++i)
    {
        cloud.points[i].x = 512 * rand () / (RAND_MAX + 1.0f);
        cloud.points[i].y = 512 * rand () / (RAND_MAX + 1.0f);
        cloud.points[i].z = 512 * rand () / (RAND_MAX + 1.0f);
    }
    //Convert the cloud to ROS message
    pcl::toROSMsg(cloud, output);
    output.header.frame_id = "point_cloud";
    ros::Rate loop_rate(1);
    while (ros::ok())
    {
        //publishing point cloud data
        pcl_pub.publish(output);
        ros::spinOnce();
        loop_rate.sleep();
    }
    return 0;
}

此代码段位于apprize