01 PCL总体遵循cmake型框架的执行流程,基本流程归纳如下:
工作环境(单独文件夹)下创建CMakeLists.txt文件以及.cpp文件(项目位于/PATH/TO/MY/GRAND/PROJECT路径下)
cmake_minimum_required(VERSION 2.6 FATAL_ERROR)//cmake版本 project(MY_GRAND_PROJECT)//项目命名 find_package(PCL 1.3 REQUIRED COMPONENT common io)// PCL包及必需组件io include_directories(${PCL_INCLUDE_DIRS})//设置为PCL安装的标头和依赖标头的路径 link_directories(${PCL_LIBRARY_DIRS})//设置为PCL库和第三方依赖关系所在的路径 add_definitions(${PCL_DEFINITIONS})//列出所需的预处理程序定义和编译器标志 add_executable(pcd_write_test pcd_write.cpp)//告诉cmake我们正在尝试pcd_write_test
从一个源文件中创建一个可执行文件pcd_write.cpp
target_link_libraries(pcd_write_test ${PCL_LIBRARIES})//设置为已建立和已安装的PCL库的文件名
注释:找到PCL后,将设置几个相关变量:
-
PCL_FOUND:如果找到PCL,则设置为1,否则未设置
-
PCL_INCLUDE_DIRS:设置为PCL安装的标头和依赖标头的路径
-
PCL_LIBRARIES:设置为已建立和已安装的PCL库的文件名
-
PCL_LIBRARY_DIRS:设置为PCL库和第三方依赖关系所在的路径
-
PCL_VERSION:找到的PCL的版本
-
PCL_COMPONENTS:列出所有可用的组件
-
PCL_DEFINITIONS:列出所需的预处理程序定义和编译器标志
总结:
我们正在构建的可执行文件可以调用PCL函数。到目前为止,我们仅包括PCL头文件,因此编译器知道我们正在调用的方法。我们还需要使链接程序知道我们要链接的库。如前所述,PCL发现的库是使用PCL_LIBRARIES
变量引用的,剩下的只是触发我们调用target_link_libraries()
宏的链接操作 。PCLConfig.cmake使用一个名为EXPORT的CMake特殊功能,该功能允许您使用其他项目目标,就像您自己构建它们一样。使用此类目标时,它们称为导入目标,其作用与其他任何目标一样。
02 编译和运行
(a)创建build目录,进行编译
cd /PATH/TO/MY/GRAND/PROJECT mkdir build cd build cmake .. //编译
(b)构建项目
make
(c)项目已编译,链接并可以进行测试:
./pcd_write_test
综上,与其它依靠cmake编译的类具有相似的编译过程!