Point Cloud Library (PCL) for Python - pclpy 安装指南 (2)

Point Cloud Library (PCL) for Python - pclpy 安装指南 (1)

  1. 导入库

    python 复制代码
    from pclpy import pcl
    import numpy as np

    导入pclpy库中的pcl模块,用于处理点云数据。numpy库用于处理数值数据。

  2. 读取点云

    python 复制代码
    cloud = pcl.PointCloud.PointXYZRGB()
    pcl.io.loadPCDFile('F:\\bunny.pcd', cloud)
    • cloud = pcl.PointCloud.PointXYZRGB():创建一个存储点云数据的对象,类型为PointXYZRGB,即包含颜色信息的点云。
    • pcl.io.loadPCDFile('F:\\bunny.pcd', cloud):从指定路径加载PCD文件,并将数据存储到cloud对象中。
  3. 打印点云信息

    python 复制代码
    print('读取点云的点数为:', cloud.size())
    print('点云坐标为:', np.asarray(cloud.xyz))
    • cloud.size():获取点云中的点数。
    • np.asarray(cloud.xyz):将点云坐标转换为numpy数组,并打印出来。
  4. 可视化点云

    python 复制代码
    viewer = pcl.visualization.PCLVisualizer("3D Viewer")
    viewer.setBackgroundColor(0, 0, 0)
    rgb = pcl.visualization.PointCloudColorHandlerRGBField.PointXYZRGB(cloud)
    viewer.addPointCloud(cloud, rgb)
    • viewer = pcl.visualization.PCLVisualizer("3D Viewer"):创建一个可视化对象,窗口名为"3D Viewer"。
    • viewer.setBackgroundColor(0, 0, 0):设置窗口背景颜色为黑色。
    • rgb = pcl.visualization.PointCloudColorHandlerRGBField.PointXYZRGB(cloud):获取点云的颜色信息。
    • viewer.addPointCloud(cloud, rgb):将点云和颜色信息添加到可视化对象中。
  5. 添加坐标系和初始化相机参数

    python 复制代码
    viewer.addCoordinateSystem(1.0)
    viewer.initCameraParameters()
    • viewer.addCoordinateSystem(1.0):在可视化窗口中添加一个坐标系,便于观察点云的方向和位置。
    • viewer.initCameraParameters():初始化相机参数,使得初始视角更合理。
  6. 循环展示

    python 复制代码
    while not viewer.wasStopped():
        viewer.spinOnce(10)
    • while not viewer.wasStopped():循环检查窗口是否被关闭。
    • viewer.spinOnce(10):更新可视化窗口,参数10表示每次循环的时间间隔(毫秒)。
  7. 完整代码

    python 复制代码
    from pclpy import pcl
    import numpy as np
    
    def main():
        cloud = pcl.PointCloud.PointXYZRGB()
        pcl.io.loadPCDFile('F:\\bunny.pcd', cloud)
        
        print('Number of points in the point cloud:', cloud.size())
        print('Point cloud coordinates:', np.asarray(cloud.xyz))
    
        viewer = pcl.visualization.PCLVisualizer("3D Viewer")
        viewer.setBackgroundColor(0, 0, 0)
        rgb = pcl.visualization.PointCloudColorHandlerRGBField.PointXYZRGB(cloud)
        viewer.addPointCloud(cloud, rgb)
    
        while not viewer.wasStopped():
            viewer.spinOnce(10)
    
    if __name__ == '__main__':
        main()
  1. PCD文件

    下载PCD文件

相关推荐
小北方城市网1 分钟前
第 6 课:全栈项目性能 & 安全双进阶 ——Redis 缓存 + JWT 认证(打造高并发高安全后端)
开发语言·数据库·redis·python·安全·缓存·数据库架构
flysh058 分钟前
C# 核心进阶:深度解析继承(Inheritance)与多态机制
开发语言·c#
TianYaKe-天涯客10 分钟前
线性回归分析及Python数据可视化
python
默默前行的虫虫14 分钟前
Open-Meteo完全免费的天气 API查询
python
kylezhao201914 分钟前
第二节、C# 上位机核心数据类型详解(工控场景实战版)
开发语言·c#·上位机
qq_3930604716 分钟前
公x课视频播放
开发语言·python·音视频
seabirdssss16 分钟前
修改联想电脑的截图保存位置
windows·经验分享·笔记
郝学胜-神的一滴21 分钟前
Qt实现窗口阴影之美:光影交错间的界面艺术
开发语言·c++·qt·软件工程
问道飞鱼25 分钟前
【桌面应用开发】Windows 环境下 Dioxus 桌面应用开发环境搭建
windows·桌面应用·dioxus开发
闻缺陷则喜何志丹29 分钟前
【二分查找】P9822 [ICPC2020 Shanghai R] Walker【有误差】|普及
开发语言·算法·r语言