(1)学习向PCD文件写入点云数据

建立工程文件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中支持的点类型的头文件intmain (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  buildcd buildcmake ..make

生成可执行文件后执行的结果:

(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>);这是声明的数据类型,用来存储我们打开的点云数据格式,是共享指针类型

关注“点云PCL”微信公众号,与小伙伴们一起交流吧!

C 怎么读取Cpp文件_从PCD文件写入和读取点云数据相关推荐

  1. 点云学习笔记19——使用pcl将bin文件转化为pcd文件

    从KITTI下载的数据是二进制bin格式,但是pcl似乎只能读取pcd文件,为了可视化,先将bin文件转换为pcd文件. 在home下,新建文件夹PointCloud(我建在这里,大家随意),在Poi ...

  2. 使用pcl将bin文件转化为pcd文件

    使用pcl将bin文件转化为pcd文件 环境搭载:ubuntu16.04 之后正式操作具体如下: 在home下,新建文件夹PointCloud(我建在这里,大家随意),在PointCloud文件里继续 ...

  3. python 把txt文件转化为pcd文件并用open3D可视化

    python 把txt文件转化为pcd文件并用open3D进行可视化 最近在弄3D点云的一些东西,遇到一个问题:很多数据集给的点云数据都是txt格式的,但是在模型上用到的数据集基本是pcd格式!找了很 ...

  4. Pcap文件转化成Pcd文件

    通过RSview将点云文件保存成了Pcap格式,但这种格式不能很好的支持PCL点云库,故不能很好的实现点云获取.滤波.分割.配准.检索.特征提取.识别.追踪.曲面重建.可视化等,因此我们需要将Pcap ...

  5. pydicom读取头文件_.dcm格式文件软件读取及python处理详解

    要处理一些.dcm格式的焊接缺陷图像,需要读取和显示.dcm格式的图像.通过搜集资料收集到一些医学影像,并通过pydicom模块查看.dcm格式文件. 若要查看dcm格式文件,可下echo viewe ...

  6. java 循环读取文件_您如何用Java连续读取文件?

    小编典典 这有点旧,但是我已经使用了该机制,并且效果很好. 诀窍是使用java.io.RandomAccessFile和,并定期检查文件长度是否大于当前文件位置.如果是,则读取数据.当您达到长度时,您 ...

  7. fileinputstream resources 读取文件_压缩20M文件从30秒到1秒,包教包会

    作者:不学无数的程序员链接:https://www.jianshu.com/p/25b328753017 压缩20M文件从30秒到1秒的优化过程 有一个需求需要将前端传过来的10张照片,然后后端进行处 ...

  8. python输入文件名读取文件_[Python] python3 文件操作:从键盘输入、打开关闭文件、读取写入文件、重命名与删除文件等...

    1.从键盘输入 Python 2有两个内置的函数用于从标准输入读取数据,默认情况下来自键盘.这两个函数分别是:input()和raw_input(). Python 3中,不建议使用raw_input ...

  9. python打开并读取csv文件_!python3中使用使用read_csv( )读取csv文件,文件路径中含有中文,无法读取怎么处理?...

    python3如何根据csv文件的列的内容,自动建数据库表 你好,csv格式的和excel格式是差不多的, 下面是读取excel的一些函数,希望帮到你: # -*- coding: cp936 -*- ...

最新文章

  1. ubuntu linux下建立stm32开发环境: 程序烧录 openocd+openjtag
  2. DDIA笔记—第六章 数据分区
  3. FCN-Fully Convolutional Networks
  4. 开源web应用防火墙 - Naxsi
  5. db2如何锁定一张表_DB2数据库为单个会话锁定的技巧
  6. linux值centos7安装docker
  7. 串口硬盘如何应用于并口硬盘计算机,串口硬盘和并口硬盘的区别 并口硬盘怎么改串口硬盘【详解】...
  8. Tomcat 中 tomcat9.exe 和 tomcat9w.exe 的使用
  9. 移动交互设计:提示语设计总结
  10. # 量子力学中叠加态、本征态、混合态、纯态、纠缠态、直积态的区别(百度整理来的)
  11. WWDC 2016 印象初步
  12. Flash制作卷轴水墨画展开动画效果
  13. Inception-V3论文翻译——中文版
  14. Gazebo物理仿真环境搭建 实例
  15. 华为服务器修改硬盘显示顺序,服务器硬盘顺序
  16. javaweb JAVA JSP水费管理系统JSP电费管理系统JSP缴费管理系统JSP水费缴费系统JSP水电费管理
  17. 数据仓库-6.元数据管理
  18. 常见虚拟机及网络模式
  19. 2000-2017年全球人口密度数据下载LandScan
  20. 主成分回归之后预测_回归分析|笔记整理(B)——主成分回归(下),偏最小二乘回归...

热门文章

  1. Unity.Interception System (2.0)
  2. 数据结构——图的C语言实现
  3. 第二章 数据的表示和运算 2.1.3 字符与字符串 [计算机组成原理笔记]
  4. linux下的单机工具,Linux下单机模式的Hadoop部署
  5. meanshift算法 java_Meanshift,聚类算法
  6. 惠普打印机136w硒鼓芯片怎么清零_关于惠普彩激升级后无法识别硒鼓的处理方案...
  7. Python实现一个数组除以一个数
  8. QT学习笔记(十四):QLayout的属性介绍
  9. Viola-Jones人脸检测详解
  10. 数据结构之二叉搜索树