1 PCL库
1.1 PCL下载
之前配置完成,现在换了工作站,需要在工作站上重新配置环境,记录一下,便于以后提出改进。
访问Github,在搜索栏搜索PCL,找到PCL的存储库。
链接: github-PCL
选择自己想用的版本。
1.2 PCL安装
其中,安装之后PCL文件夹和OpenNI2文件夹并列,此时将并列的OpenNI2文件夹内文件有库,而3rdParty下面的有卸载和安装程序(.msi文件)。为保持方便,将3rdParty下面的OpenNI2卸载掉(在控制面板中将安装的OpenNI卸载,选择3rdParty中的msi文件进行安装),重新安装,安装路径放置在PCL\3rdParty\OpenNI2下。
OpenNI2安装完毕后面,呈现上图结果。
所有就绪后,将压缩包文件解压,所有的.pdb文件复制粘贴进入安装路径的bin文件夹中。
1.3 环境配置
新增的环境变量。
你可自己往里面添加绝对路径也可以相对路径,带百分号的是绝对路径。
// 以默认路径的绝对路径为例
C:\Program Files\PCL 1.12.0\bin
C:\Program Files\PCL 1.12.0\3rdParty\Boost\bin
C:\Program Files\PCL 1.12.0\3rdParty\FLANN\bin
C:\Program Files\PCL 1.12.0\3rdParty\Qhull\bin
C:\Program Files\PCL 1.12.0\3rdParty\VTK\bin
C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Redist
C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Tools
2 配置VS环境
2.1 添加包含目录
// 默认安装的路径
C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Include
C:\Program Files\PCL 1.12.0\3rdParty\Boost\include\boost-1_76
C:\Program Files\PCL 1.12.0\include\pcl-1.12
C:\Program Files\PCL 1.12.0\3rdParty\Qhull\include
C:\Program Files\PCL 1.12.0\3rdParty\VTK\include\vtk-9.0
C:\Program Files\PCL 1.12.0\3rdParty\FLANN\include
C:\Program Files\PCL 1.12.0\3rdParty\Eigen\eigen3
2.2 添加库目录
// 库目录
C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Lib
C:\Program Files\PCL 1.12.0\3rdParty\VTK\lib
C:\Program Files\PCL 1.12.0\3rdParty\Qhull\lib
C:\Program Files\PCL 1.12.0\3rdParty\FLANN\lib
C:\Program Files\PCL 1.12.0\3rdParty\Boost\lib
C:\Program Files\PCL 1.12.0\lib
2.3 配置调试属性
//环境PATH(根据自己电脑路径进行配置)
PATH=C:\Program Files\PCL 1.12.0\bin;C:\Program Files\PCL 1.12.0\3rdParty\VTK\bin;C:\Program Files\PCL 1.12.0\3rdParty\FLANN\bin;C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Redist;C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Lib;C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Include;C:\Program Files\PCL 1.12.0\3rdParty\OpenNI2\Tools
C/C++——语言——符合模式
C/C++——常规——SDL检查
C/C++——预处理器——定义
// 新增下面三条语句
BOOST_USE_WINDOWS_H
NOMINMAX
_CRT_SECURE_NO_DEPRECATE
2.4 添加依赖项
// 1.20.0版本中依赖项
OpenNI2.lib
vtkChartsCore-9.0d.lib
vtkCommonColor-9.0d.lib
vtkCommonComputationalGeometry-9.0d.lib
vtkCommonCore-9.0d.lib
vtkCommonDataModel-9.0d.lib
vtkCommonExecutionModel-9.0d.lib
vtkCommonMath-9.0d.lib
vtkCommonMisc-9.0d.lib
vtkCommonSystem-9.0d.lib
vtkCommonTransforms-9.0d.lib
vtkDICOMParser-9.0d.lib
vtkDomainsChemistry-9.0d.lib
vtkDomainsChemistryOpenGL2-9.0d.lib
vtkdoubleconversion-9.0d.lib
vtkexodusII-9.0d.lib
vtkexpat-9.0d.lib
vtkFiltersAMR-9.0d.lib
vtkFiltersCore-9.0d.lib
vtkFiltersExtraction-9.0d.lib
vtkFiltersFlowPaths-9.0d.lib
vtkFiltersGeneral-9.0d.lib
vtkFiltersGeneric-9.0d.lib
vtkFiltersGeometry-9.0d.lib
vtkFiltersHybrid-9.0d.lib
vtkFiltersHyperTree-9.0d.lib
vtkFiltersImaging-9.0d.lib
vtkFiltersModeling-9.0d.lib
vtkFiltersParallel-9.0d.lib
vtkFiltersParallelImaging-9.0d.lib
vtkFiltersPoints-9.0d.lib
vtkFiltersProgrammable-9.0d.lib
vtkFiltersSelection-9.0d.lib
vtkFiltersSMP-9.0d.lib
vtkFiltersSources-9.0d.lib
vtkFiltersStatistics-9.0d.lib
vtkFiltersTexture-9.0d.lib
vtkFiltersTopology-9.0d.lib
vtkFiltersVerdict-9.0d.lib
vtkfreetype-9.0d.lib
vtkGeovisCore-9.0d.lib
vtkgl2ps-9.0d.lib
vtkglew-9.0d.lib
vtkhdf5-9.0d.lib
vtkhdf5_hl-9.0d.lib
vtkImagingColor-9.0d.lib
vtkImagingColor-9.0.lib
vtkImagingCore-9.0d.lib
vtkImagingCore-9.0.lib
vtkImagingFourier-9.0d.lib
vtkImagingFourier-9.0.lib
vtkImagingGeneral-9.0d.lib
vtkImagingGeneral-9.0.lib
vtkImagingHybrid-9.0d.lib
vtkImagingHybrid-9.0.lib
vtkImagingMath-9.0d.lib
vtkImagingMath-9.0.lib
vtkImagingMorphological-9.0d.lib
vtkImagingMorphological-9.0.lib
vtkImagingSources-9.0d.lib
vtkImagingSources-9.0.lib
vtkImagingStatistics-9.0d.lib
vtkImagingStatistics-9.0.lib
vtkImagingStencil-9.0d.lib
vtkImagingStencil-9.0.lib
vtkInfovisCore-9.0d.lib
vtkInfovisLayout-9.0d.lib
vtkInteractionImage-9.0d.lib
vtkInteractionStyle-9.0d.lib
vtkInteractionWidgets-9.0d.lib
vtkIOAMR-9.0d.lib
vtkIOAsynchronous-9.0d.lib
vtkIOCityGML-9.0d.lib
vtkIOCore-9.0d.lib
vtkIOEnSight-9.0d.lib
vtkIOExodus-9.0d.lib
vtkIOExport-9.0d.lib
vtkIOExportGL2PS-9.0d.lib
vtkIOExportPDF-9.0d.lib
vtkIOGeometry-9.0d.lib
vtkIOImage-9.0d.lib
vtkIOImport-9.0d.lib
vtkIOInfovis-9.0d.lib
vtkIOLegacy-9.0d.lib
vtkIOLSDyna-9.0d.lib
vtkIOMINC-9.0d.lib
vtkIOMovie-9.0d.lib
vtkIONetCDF-9.0d.lib
vtkIOParallel-9.0d.lib
vtkIOParallelXML-9.0d.lib
vtkIOPLY-9.0d.lib
vtkIOSegY-9.0d.lib
vtkIOSQL-9.0d.lib
vtkIOTecplotTable-9.0d.lib
vtkIOVeraOut-9.0d.lib
vtkIOVideo-9.0d.lib
vtkIOXML-9.0d.lib
vtkIOXMLParser-9.0d.lib
vtkjpeg-9.0d.lib
vtkjsoncpp-9.0d.lib
vtklibharu-9.0d.lib
vtklibxml2-9.0d.lib
vtklz4-9.0d.lib
vtklzma-9.0d.lib
vtkmetaio-9.0d.lib
vtkNetCDF-9.0d.lib
vtkogg-9.0d.lib
vtkParallelCore-9.0d.lib
vtkpng-9.0d.lib
vtkpugixml-9.0d.lib
vtkRenderingAnnotation-9.0d.lib
vtkRenderingContext2D-9.0d.lib
vtkRenderingContextOpenGL2-9.0d.lib
vtkRenderingCore-9.0d.lib
vtkRenderingFreeType-9.0d.lib
vtkRenderingGL2PSOpenGL2-9.0d.lib
vtkRenderingImage-9.0d.lib
vtkRenderingLabel-9.0d.lib
vtkRenderingLOD-9.0d.lib
vtkRenderingOpenGL2-9.0d.lib
vtkRenderingVolume-9.0d.lib
vtkRenderingVolumeOpenGL2-9.0d.lib
vtksqlite-9.0d.lib
vtksys-9.0d.lib
vtktheora-9.0d.lib
vtktiff-9.0d.lib
vtkverdict-9.0d.lib
vtkViewsContext2D-9.0d.lib
vtkViewsCore-9.0d.lib
vtkViewsInfovis-9.0d.lib
vtkzlib-9.0d.lib
pcl_commond.lib
pcl_featuresd.lib
pcl_filtersd.lib
pcl_iod.lib
pcl_io_plyd.lib
pcl_kdtreed.lib
pcl_keypointsd.lib
pcl_mld.lib
pcl_octreed.lib
pcl_outofcored.lib
pcl_peopled.lib
pcl_recognitiond.lib
pcl_registrationd.lib
pcl_sample_consensusd.lib
pcl_searchd.lib
pcl_segmentationd.lib
pcl_stereod.lib
pcl_surfaced.lib
pcl_trackingd.lib
pcl_visualizationd.lib
3 点云代码测试
// An highlighted block
#include <pcl/visualization/cloud_viewer.h>
#include <iostream>
#include <pcl/io/io.h>
#include <pcl/io/pcd_io.h>
#include <pcl/io/ply_io.h>
#include <pcl/point_types.h>
using namespace pcl;
using namespace pcl::io;
int user_data;
void
viewerOneOff(pcl::visualization::PCLVisualizer& viewer)
{
viewer.setBackgroundColor(1.0, 0.5, 1.0);
pcl::PointXYZ o;
o.x = 1.0;
o.y = 0;
o.z = 0;
//viewer.addSphere(o, 0.25, "sphere", 0);
std::cout << "i only run once" << std::endl;
}
void
viewerPsycho(pcl::visualization::PCLVisualizer& viewer)
{
static unsigned count = 0;
std::stringstream ss;
ss << "Once per viewer loop: " << count++;
//viewer.removeShape("text", 0);
//viewer.addText(ss.str(), 200, 300, "text", 0);
//FIXME: possible race condition here:
user_data++;
}
int
main()
{
pcl::PLYReader reader;
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud1(new pcl::PointCloud<pcl::PointXYZ>);
reader.read<pcl::PointXYZ>("F:\\data_pointcloud\\rabbit\\bun000.ply", *cloud1);
pcl::io::savePCDFile("F:\\data_pointcloud\\rabbit\\bun000.pcd", *cloud1);
pcl::PointCloud<pcl::PointXYZRGBA>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZRGBA>);
pcl::io::loadPCDFile("F:\\data_pointcloud\\rabbit\\bun000.pcd", *cloud);
pcl::visualization::CloudViewer viewer("Cloud Viewer");
//blocks until the cloud is actually rendered
viewer.showCloud(cloud);
//use the following functions to get access to the underlying more advanced/powerful
//PCLVisualizer
//This will only get called once
viewer.runOnVisualizationThreadOnce(viewerOneOff);
//This will get called once per visualization iteration
viewer.runOnVisualizationThread(viewerPsycho);
while (!viewer.wasStopped())
{
//you can also do cool processing here
//FIXME: Note that this is running in a separate thread from viewerPsycho
//and you should guard against race conditions yourself...
user_data++;
}
return 0;
}
运行结果
斯坦福兔子,在网上应该都能搜到。如果需要点云文件,可以后台联系。