pcl 保存点云.ply 格式 or .pcd格式

转自:http://www.pcl-users.org/pcl-io-savePLYFile-crashing-in-Visual-studio-td4042792.html

I installed pcl on windows machine today as i intend to use it in a mex function for my matlab project and wanted a working windows version of pcl. i ran a sample code shown below to generate 50 points and save them in a PCD and PLY file. However, for some reaosn savePLYFILE is crashing my program while savePCDFILE works fine. I am at a loss to epxlain this ( i do need my PC in ply format so i can open them in meshlab).  Here is the code: 

#include <iostream>
#include <pcl/io/pcd_io.h>
#include <pcl/io/ply_io.h>
#include <pcl/point_types.h>
#include <pcl/common/io.h>
#include <pcl/impl/point_types.hpp>
#include <pcl/point_cloud.h>


int  main (int argc, char** argv) 
{ 
  pcl::PointCloud<pcl::PointXYZ> cloud; 
  pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_ptr = pcl::PointCloud<pcl::PointXYZ>::Ptr (new pcl::PointCloud<pcl::PointXYZ>); 
  // Fill in the cloud data 
  cloud.width    = 50; 
  cloud.height   = 1; 
  cloud.is_dense = false; 
  cloud.points.resize (cloud.width * cloud.height); 
  
  cloud_ptr->width = cloud.width ; 
  cloud_ptr->height = cloud.height; 
  cloud_ptr->is_dense = cloud.is_dense; 
 // cloud_ptr->points.resize (cloud.width * cloud.height); 

  for (size_t i = 0; i < cloud.points.size (); ++i) 
  { 
   // cloud.points[i].x = 1024 * rand () / (RAND_MAX + 1.0f); 
   // cloud.points[i].y = 1024 * rand () / (RAND_MAX + 1.0f); 
   // cloud.points[i].z = 1024 * rand () / (RAND_MAX + 1.0f); 

        pcl::PointXYZ p; 
        p.x = 1024 * rand () / (RAND_MAX + 1.0f); 
        p.y = 1024 * rand () / (RAND_MAX + 1.0f); 
        p.z = 1024 * rand () / (RAND_MAX + 1.0f); 
        cloud.points[i].x = p.x; 
        cloud.points[i].y = p.y; 
        cloud.points[i].z = p.z; 

        cloud_ptr->points.push_back(p); 
  } 
  std::cerr << "Saving to pcd file " << std::endl; 
  pcl::io::savePCDFileASCII ("test_pcd0.pcd", cloud); 
  pcl::io::savePCDFile ("test_pcd1.pcd", *cloud_ptr); 
  std::cerr << "Saved " << cloud.points.size () << " data points to test_pcd.pcd." << std::endl; 

  std::cerr << "Saving to ply file " << std::endl; 
  pcl::io::savePLYFile ("test_ply.ply", cloud); 

  for (size_t i = 0; i < cloud.points.size (); ++i){ 
  //  std::cerr << "    " << cloud.points[i].x << " " << cloud.points[i].y << " " << cloud.points[i].z << std::endl; 
          std::cerr << "    " << cloud_ptr->points[i].x << " " << cloud_ptr->points[i].y << " " << cloud_ptr->points[i].z << std::endl; 
  } 

  return (0); 
} 

 

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
在Visual Studio中实现点云格式从.pcd转换为.ply格式的代码,可以参考以下示例代码: ``` #include <iostream> #include <pcl/io/pcd_io.h> #include <pcl/io/ply_io.h> #include <pcl/point_types.h> int main(int argc, char** argv) { // Load .pcd file pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>); if (pcl::io::loadPCDFile<pcl::PointXYZ>("input_cloud.pcd", *cloud) == -1) { PCL_ERROR("Couldn't read file input_cloud.pcd\n"); return (-1); } std::cout << "Loaded " << cloud->width * cloud->height << " data points from input_cloud.pcd" << std::endl; // Convert to .ply format pcl::PointCloud<pcl::PointXYZRGB>::Ptr ply_cloud(new pcl::PointCloud<pcl::PointXYZRGB>); pcl::copyPointCloud(*cloud, *ply_cloud); for (size_t i = 0; i < ply_cloud->size(); ++i) { ply_cloud->points[i].r = 255; ply_cloud->points[i].g = 255; ply_cloud->points[i].b = 255; } // Save .ply file pcl::io::savePLYFileASCII("output_cloud.ply", *ply_cloud); std::cout << "Saved " << ply_cloud->width * ply_cloud->height << " data points to output_cloud.ply" << std::endl; return 0; } ``` 此代码同样使用了PCL库,首先从.pcd文件中加载点云数据,然后使用`pcl::copyPointCloud()`函数将点云数据转换为.ply格式,并将所有点云颜色设置为白色。最后使用`pcl::io::savePLYFileASCII()`函数将转换后的点云数据保存为.ply格式文件。注意,此代码仅适用于点云类型为pcl::PointXYZ的情况,如果点云类型不同,需要相应地修改代码。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值