PCL :实现 提取两片点云的重叠部分并保存
PCL :实现 提取两片点云的重叠部分并保存
#include <iostream>
#include <pcl/io/pcd_io.h>
#include <pcl/point_types.h>
#include <pcl/filters/extract_indices.h>
#include <pcl/registration/icp.h>
int main(int argc, char** argv)
{
// 读取两片点云数据
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud1(new pcl::PointCloud<pcl::PointXYZ>);
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud2(new pcl::PointCloud<pcl::PointXYZ>);
pcl::io::loadPCDFile<pcl::PointXYZ>("cloud1.pcd", *cloud1);
pcl::io::loadPCDFile<pcl::PointXYZ>("cloud2.pcd", *cloud2);
// 创建一个ICP对象
pcl::IterativeClosestPoint<pcl::PointXYZ, pcl::PointXYZ> icp;
// 设置ICP参数
icp.setInputSource(cloud1); // 设置源点云
icp.setInputTarget(cloud2); // 设置目标点云
icp.setMaximumIterations(100); // 设