pclpy pcd、pcl、vtk等文件读取点云、保存点云、可视化点云

一、读取点云数据

1.1 读取点云(只读取坐标,不读取颜色)

方法一

cloud = pcl.PointCloud.PointXYZ()
pcl.io.loadPCDFile('res/bunny.pcd', cloud)  # 读取点云数据在cloud中

方法二

cloud = pcl.PointCloud.PointXYZ()
reader = pcl.io.PCDReader()
reader.read("res/bunny.pcd", cloud)
1.2 读取点云(坐标,颜色)

方法一

cloud = pcl.PointCloud.PointXYZRGB()
pcl.io.loadPCDFile('res/bunny.pcd', cloud)

方法二

cloud = pcl.PointCloud.PointXYZRGB()
reader = pcl.io.PCDReader()
reader.read("res/bunny.pcd", cloud)
补充读取ply、vtk格式点云

ply格式读取

mesh = pcl.PolygonMesh()
pcl.io.loadPLYFile("res/bunny.ply", mesh)

vtk格式读取

pcl.io.loadPLYFile("messy_mesh_binary.vtk", mesh)

二、保存点云数据

1.pcd等文件保存
pcl.io.savePCDFileASCII("res/bunnyCc.pcd", cloud)
2.ply文件保存
pcl.io.savePLYFile('res/monkeyC.ply', mesh)
3.vtk文件保存
pcl.io.savePLYFile('mesh.vtk', mesh)

三、可视化点云

viewer = pcl.visualization.PCLVisualizer("3D viewer")  # 建立一个可视化对象,窗口名 3D viewer
viewer.setBackgroundColor(0, 0, 0)  # 设置窗口背景为黑色
rgb = pcl.visualization.PointCloudColorHandlerRGBField.PointXYZRGB(cloud)  # 获得点云的颜色
viewer.addPointCloud(cloud, rgb)  # 将颜色和点云数据添加到可刷对象中
while not viewer.wasStopped():  # 展示可视化对象
    viewer.spinOnce(10)

四、全代码

from pclpy import pcl
import numpy as np

if __name__ == '__main__':
    # ----------------------读取点云------------------------
    cloud = pcl.PointCloud.PointXYZRGB()
    pcl.io.loadPCDFile('res/bunny.pcd', cloud)
    print('读取点云的点数为:', cloud.size())
    print('点云坐标为:', np.asarray(cloud.xyz)[:])
    # -----------------------可视化------------------------
    viewer = pcl.visualization.PCLVisualizer("3D viewer")  # 建立一个可视化对象,窗口名 3D viewer
    viewer.setBackgroundColor(0, 0, 0)  # 设置窗口背景为黑色
    rgb = pcl.visualization.PointCloudColorHandlerRGBField.PointXYZRGB(cloud)  # 获得点云的颜色(可以没有)
    viewer.addPointCloud(cloud, rgb)  # 将颜色和点云数据添加到可刷对象中
    while not viewer.wasStopped():  # 展示可视化对象
        viewer.spinOnce(10)

五、结果

在这里插入图片描述

六、相关数据

测试数据下载链接:https://pan.baidu.com/s/1uT6UbzU5h7wPurnQYUB7TQ
提取码:lsyg

七、问题与解决方法

在这里插入图片描述
这个问题是由于点云文件导致的切换一个点云文件尝试即可。。。

  • 13
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
VTK可以读取可视化PCL点云数据。以下是一些基本步骤: 1. 确保您已经安装了VTKPCL库。 2. 加载PCL点云数据并将其转换为VTK数据格式。这可以通过使用PCL库中的vtkSmartPointer类来完成。以下是一个示例代码段: ```cpp pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>); // Load PCL point cloud data pcl::io::loadPCDFile ("your_pcl_point_cloud.pcd", *cloud); // Convert to VTK data format vtkSmartPointer<vtkPoints> points = vtkSmartPointer<vtkPoints>::New(); for (int i = 0; i < cloud->size(); i++) { pcl::PointXYZ point = cloud->points[i]; points->InsertNextPoint(point.x, point.y, point.z); } vtkSmartPointer<vtkPolyData> polydata = vtkSmartPointer<vtkPolyData>::New(); polydata->SetPoints(points); ``` 3. 使用VTK可视化工具显示点云数据。以下是一个示例代码段: ```cpp vtkSmartPointer<vtkPolyDataMapper> mapper = vtkSmartPointer<vtkPolyDataMapper>::New(); mapper->SetInputData(polydata); vtkSmartPointer<vtkActor> actor = vtkSmartPointer<vtkActor>::New(); actor->SetMapper(mapper); vtkSmartPointer<vtkRenderer> renderer = vtkSmartPointer<vtkRenderer>::New(); renderer->AddActor(actor); renderer->SetBackground(0.1, 0.2, 0.4); vtkSmartPointer<vtkRenderWindow> renderWindow = vtkSmartPointer<vtkRenderWindow>::New(); renderWindow->AddRenderer(renderer); vtkSmartPointer<vtkRenderWindowInteractor> interactor = vtkSmartPointer<vtkRenderWindowInteractor>::New(); interactor->SetRenderWindow(renderWindow); interactor->Initialize(); interactor->Start(); ``` 这将创建一个带有点云数据的3D窗口,您可以在其中旋转和缩放点云数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云杂项

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值