pcl点云保存成图片pgm和yaml,用于机器人导航规划

这段代码主要展示了如何将点云数据保存为PCD文件,然后将点云投影到图像上并保存为PGM文件。同时,还创建了一个YAML文件,包含了图像信息、分辨率和坐标框等数据。整个过程涉及到点云处理、图像处理和文件存储操作。
摘要由CSDN通过智能技术生成

话不多说直接上代码

        pcl::io::savePCDFileBinary(saveMapDirectory + "/GlobalMapProjected.pcd", *cloud_projected);

        cout << "****************************************************" << endl;
        cout << "Saving projected map to pcd files completed\n"
             << endl;

        //save pcl_points to image
        cout << "req.resolution " << req.resolution;
        std::vector<cv::Point2i> points;
        pcl::PointXYZ p_temp;

        for(int i=0; i<globalMapCloud->points.size(); i++)
        {
            cv::Point2i point;
            point.x = globalMapCloud->points[i].x / req.resolution;
            point.y = globalMapCloud->points[i].y / req.resolution;
            points.push_back(point);
        }

        cv::Rect box = cv::boundingRect(cv::Mat(points));
        cout << "cv::Rect box br x y " << box.br().x << " " << box.br().y << endl;
        cout << "cv::Rect box tl x y " << box.tl().x << " " << box.tl().y << endl;
        cout << "cv::Area box " << box.area() << endl;

        //create Mat image
        int rows = box.height;
        int cols = box.width;
        cv::Mat map_image(cols,rows, CV_8UC1, 255);

        for(int i=0; i<globalMapCloud->points.size(); i++)
        {
            int x = (globalMapCloud->points[i].x / req.resolution - box.tl().x);
            int y = (globalMapCloud->points[i].y / req.resolution - box.tl().y);

            if( x > 0 && x < cols
               && y > 0 && y < rows)
               {
                   int value_change = map_image.at<uchar>(x,y) * 0.9;
                   map_image.at<uchar>(x,y) = value_change;
               }
        }

        cv::imwrite(saveMapDirectory + "/global_map.pgm", map_image);

        //write yaml
        std::string pgm_filename = saveMapDirectory + "/global_map.pgm";
        double resolution = req.resolution;

        std::ofstream out_(saveMapDirectory + "/global_map.yaml", std::ios::out | std::ios::binary);
        const Eigen::Vector2d origin(
            box.tl().y * resolution,
            box.br().x * resolution);

        const std::string output = "image: " + pgm_filename + "\n" 
                                   + "resolution: " + std::to_string(resolution) + "\n" 
                                   + "origin: [" + std::to_string(origin.x()) + ", " + std::to_string(origin.y())
                                   + ", 0.0]\nnegate: 0\noccupied_thresh: 0.65\nfree_thresh: 0.196\n";

        if (out_.bad())
        {
            return false;
        }
        else
        {
            out_.write(output.data(), output.length());
            out_.close();

            cout << "****************************************************" << endl;
            cout << "Saving yaml map files completed\n"
                 << endl;
        }

        return !out_.bad();

可能你的坐标系和我不同,适当调整一下

PCL点云转换为ROS点云格式需要进行以下步骤: 1. 创建一个ROS节点和发布者对象。 ```cpp ros::NodeHandle nh; ros::Publisher cloud_pub = nh.advertise<sensor_msgs::PointCloud2>("point_cloud", 1); ``` 2. 创建一个PCL点云对象和ROS点云对象。 ```cpp pcl::PointCloud<pcl::PointXYZ>::Ptr pcl_cloud(new pcl::PointCloud<pcl::PointXYZ>); sensor_msgs::PointCloud2 ros_cloud; ``` 3. 将PCL点云对象转换为ROS点云对象。 ```cpp pcl::toROSMsg(*pcl_cloud, ros_cloud); ``` 4. 设置ROS点云对象的header信息。 ```cpp ros_cloud.header.frame_id = "base_link"; ros_cloud.header.stamp = ros::Time::now(); ``` 5. 发布ROS点云对象。 ```cpp cloud_pub.publish(ros_cloud); ``` 完整代码示例: ```cpp #include <ros/ros.h> #include <sensor_msgs/PointCloud2.h> #include <pcl_conversions/pcl_conversions.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_publisher"); ros::NodeHandle nh; // 创建发布者对象 ros::Publisher cloud_pub = nh.advertise<sensor_msgs::PointCloud2>("point_cloud", 1); // 创建PCL点云对象 pcl::PointCloud<pcl::PointXYZ>::Ptr pcl_cloud(new pcl::PointCloud<pcl::PointXYZ>); // 填充PCL点云对象 // 将PCL点云对象转换为ROS点云对象 sensor_msgs::PointCloud2 ros_cloud; pcl::toROSMsg(*pcl_cloud, ros_cloud); // 设置ROS点云对象的header信息 ros_cloud.header.frame_id = "base_link"; ros_cloud.header.stamp = ros::Time::now(); // 发布ROS点云对象 cloud_pub.publish(ros_cloud); // 循环等待 ros::spin(); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

可峰科技

生活不易

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值