1、参考链接
https://blog.csdn.net/qq_31254435/article/details/137799739
但是,我的方法和上述链接不大一样,我是采用VS2019进行编译的,方便在Windows平台上验证各种算法。
2、创建一个VS2019的C++ Console工程
#include <iostream>
#include <open3d/Open3D.h>
int main() {
using namespace open3d::geometry;
auto sphere = TriangleMesh::CreateSphere(1.0, 4);
sphere->ComputeVertexNormals();
sphere->PaintUniformColor({ 1, 0.706, 0 });
std::cout << sphere->vertices_.size() << " vertices\n";
std::cout << sphere->triangles_.size() << " triangles\n";
open3d::visualization::DrawGeometries({ sphere });
}
data:image/s3,"s3://crabby-images/9ae32/9ae328b1f1d8d8d0ddb196694eda62ff5b39e1c5" alt=""
Include目录:
data:image/s3,"s3://crabby-images/5481c/5481c26cfc11c1f498e068cdb84d29a341e01d74" alt=""
库目录:
data:image/s3,"s3://crabby-images/1bc60/1bc602a5a7573671ae75c780da660932e93fd0df" alt=""
3、将Open3D.dll放入到系统的Path当中
data:image/s3,"s3://crabby-images/d9357/d93574aa4204f63fa6f8e9bd65d2360014316404" alt=""
data:image/s3,"s3://crabby-images/9cfc4/9cfc4252c50df2c8b682a91b73839ec38bb37764" alt=""
data:image/s3,"s3://crabby-images/1abc0/1abc0c4b581045615f6ab82fd7661019dde1ccf6" alt=""
4、运行效果
data:image/s3,"s3://crabby-images/7d534/7d5349323f8bcb278f6149f5076f56c1d6ae4abb" alt=""
5、载入一个PLY文件显示
#include <iostream>
#include <open3d/Open3D.h>
int main()
{
std::string file_path = "E:\\PDAL\\PDAL\\bin\\t2.ply";
// 创建 PointCloud 对象
open3d::geometry::PointCloud point_cloud;
// 创建读取选项(可以根据需要添加参数)
open3d::io::ReadPointCloudOption params;
// 读取 PLY 文件
if (!open3d::io::ReadPointCloudFromPLY(file_path, point_cloud, params)) {
std::cerr << "Failed to load PLY file: " << file_path << std::endl;
return 1;
}
// 对点云进行法线估计
point_cloud.EstimateNormals(open3d::geometry::KDTreeSearchParamHybrid(0.1, 30));
// 缩放点云
double scale_factor = 10.0; // 调整此因子以改变点云大小
for (auto& point : point_cloud.points_) {
point = point * scale_factor;
}
// 创建可视化窗口
open3d::visualization::Visualizer visualizer;
visualizer.CreateVisualizerWindow("Point Cloud from PLY", 1024, 768);
// 使用 std::make_shared 将 PointCloud 转换为 std::shared_ptr
visualizer.AddGeometry(std::make_shared<const open3d::geometry::PointCloud>(point_cloud));
visualizer.Run();
visualizer.DestroyVisualizerWindow();
return 0;
}
data:image/s3,"s3://crabby-images/a8c80/a8c80c1f2a77f6f3c0ab5d8bb69b4a79954de5e2" alt=""
(愿意点赞和收藏的小伙伴,不妨关注我,我正在寻求涨粉)