從PCD文件寫入和讀取點雲數據

   (1)學習向PCD文件寫入點雲數據ios

             創建工程文件ch2,而後新建write_pcd.cpp  CMakeLists.txt兩個文件微信

  write_pcd.cpp :
數據結構

#include <iostream>              //標準C++庫中的輸入輸出的頭文件
#include <pcl/io/pcd_io.h>           //PCD讀寫類相關的頭文件
#include <pcl/point_types.h>      //PCL中支持的點類型的頭文件

int
  main (int argc, char** argv)
{
  //實例化的模板類PointCloud  每個點的類型都設置爲pcl::PointXYZ
/*************************************************
 點PointXYZ類型對應的數據結構
    Structure PointXYZ{
     float x;
     float y;
     float z;
    };
**************************************************/
  pcl::PointCloud<pcl::PointXYZ> cloud;

  // 建立點雲  並設置適當的參數(width height is_dense)
  cloud.width    = 5;
  cloud.height   = 1;
  cloud.is_dense = false;  //不是稠密型的
  cloud.points.resize (cloud.width * cloud.height);  //點雲總數大小
   //用隨機數的值填充PointCloud點雲對象 
  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);
  }
  //把PointCloud對象數據存儲在 test_pcd.pcd文件中
  pcl::io::savePCDFileASCII ("test_pcd.pcd", cloud);
  
//打印輸出存儲的點雲數據
  std::cerr << "Saved " << cloud.points.size () << " data points to test_pcd.pcd." << std::endl;

  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;

  return (0);
}

 

CMakeLists.txt:(第一次接觸CMake因此註釋的比較多,廢話比較多,因此有助於理解)模塊化

cmake_minimum_required ( VERSION 2.6 FATAL_ERROR)   #對於cmake版本的最低版本的要求
project(ch2)                                        #創建的工程名,例如源代碼目錄路徑的變量名爲CH_DIR
                                                    #工程存儲目錄變量名爲CH_BINARY_DIR
#要求工程依賴的PCL最低版本爲1.3,而且版本至少包含common和IO兩個模塊  這裏的REQUIRED意味着若是對應的庫找不到 則CMake配置的過程將徹底失敗,
#由於PCL是模塊化的,也能夠以下操做:
#           一個組件  find_package(PCL 1.6 REQUIRED COMPONENTS  io)
#           多個組件  find_package(PCL 1.6 REQUIRED COMPONENTS commom io)
#           全部組件  find_package(PCL 1.6 REQUIRED )                    
find_package(PCL 1.3 REQUIRED)  


#下面的語句是利用CMake的宏完成對PCL的頭文件路徑和連接路徑變量的配置和添加,若是缺乏下面幾行,生成文件的過程當中就會提示
#找不到相關的頭文件,在配置CMake時,當找到了安裝的PCL,下面相關的包含的頭文件,連接庫,路徑變量就會自動設置
#                    PCL_FOUND:若是找到了就會被設置爲1 ,不然就不設置
#                    PCL_INCLUDE_DIRS:被設置爲PCL安裝的頭文件和依賴頭文件的目錄
#                    PCL_LIBRARIES:被設置成所創建和安裝的PCL庫頭文件
#                    PCL_LIBRARIES_DIRS:被設置成PCL庫和第三方依賴的頭文件所在的目錄
#                    PCL_VERSION:所找到的PCL的版本
#                    PCL_COMPONENTS:列出全部可用的組件
#                    PCL_DEFINITIONS:列出所須要的預處理器定義和編譯器標誌
include_directories(${PCL_INCLUDE_DIRS})
link_directories(${PCL_LIBRARIES_DIRS})
add_definitions(${PCL_DEFINITIONS})

#這句話告訴CMake從單個源文件write_pcd創建一個可執行文件
add_executable(write_pcd write_pcd.cpp)
#雖然包含了PCL的頭文件,所以編譯器知道咱們如今訪問所用的方法,咱們也須要讓連接器知道所連接的庫,PCL找到庫文件由
#PCL_COMMON_LIBRARIES變量指示,經過target_link_libraries這個宏來出發連接操做
target_link_libraries(write_pcd ${PCL_COMMON_LIBRARIES} ${PCL_IO_LIBRARIES})
 

以後就 cd   到文件下學習

                   mkdir  buildui

                   cd buildspa

 

                   cmake ..指針

                   makecode

生成可執行文件後執行的結果:orm

 

(2)學習如何從PCD文件讀取點雲數據

讀取PCD點雲數據只需在工程文件下創建新的文件write_pcd.cpp

write.cpp:

#include <iostream>              //標準C++庫中的輸入輸出的頭文件
#include <pcl/io/pcd_io.h>       //PCD讀寫類相關的頭文件
#include <pcl/point_types.h>     //PCL中支持的點類型的頭文件

int
main (int argc, char** argv)
{ 
   //建立一個PointCloud<pcl::PointXYZ>    boost共享指針並進行實例化
  pcl::PointCloud<pcl::PointXYZ>::Ptr cloud (new pcl::PointCloud<pcl::PointXYZ>);
  
  //打開點雲文件
  if (pcl::io::loadPCDFile<pcl::PointXYZ> ("test_pcd.pcd", *cloud) == -1) 
  {
    PCL_ERROR ("Couldn't read file test_pcd.pcd \n");
    return (-1);
  }
//默認就是而二進制塊讀取轉換爲模塊化的PointCLoud格式裏pcl::PointXYZ做爲點類型  而後打印出來
  std::cout << "Loaded "
            << cloud->width * cloud->height
            << " data points from test_pcd.pcd with the following fields: "
            << std::endl;
  for (size_t i = 0; i < cloud->points.size (); ++i)
    std::cout << "    " << cloud->points[i].x
              << " "    << cloud->points[i].y
              << " "    << cloud->points[i].z << std::endl;

  return (0);
}

 

那麼要編譯此文件只需在CMakeLists.txt最下面添加兩行代碼

add_executable(write_pcd write_pcd.cpp)
add_executable(read_pcd read_pcd.cpp)
target_link_libraries(write_pcd ${PCL_COMMON_LIBRARIES} ${PCL_IO_LIBRARIES})
target_link_libraries(read_pcd ${PCL_COMMON_LIBRARIES} ${PCL_IO_LIBRARIES})

編譯後執行的結果以下

 

 若是想看PCD文件的數據,能夠找到test_pcd.pcd後綴名改成.txt便可打開以下所示:

(仔細查看文件頭 的順序也就是以前介紹的文件頭順序)

# .PCD v0.7 - Point Cloud Data file format
VERSION 0.7
FIELDS x y z
SIZE 4 4 4
TYPE F F F
COUNT 1 1 1
WIDTH 5
HEIGHT 1
VIEWPOINT 0 0 0 1 0 0 0
POINTS 5
DATA ascii
0.35222197 -0.15188313 -0.10639524
-0.3974061 -0.47310591 0.29260206
-0.73189831 0.66710472 0.44130373
-0.73476553 0.85458088 -0.036173344
-0.46070004 -0.2774682 -0.91676188

總結

pcl::PointCloud<pcl::PointXYZ> cloud ;  //寫入點雲數據的聲明,就是三個float類型的數據,

pcl::PointCloud<pcl::PointXYZ>::Ptr cloud (new pcl::PointCloud<pcl::PointXYZ>);這是聲明的數據類型,用來存儲咱們打開的點雲數據格式,是共享指針類型

微信公衆號號可掃描二維碼一塊兒共同窗習交流

未完待續******************************8

相關文章
相關標籤/搜索