使用open3D可视化各种类型的点云数据

import open3d as o3d
import numpy as np
from pyntcloud import PyntCloud
from pandas import DataFrame
def main():
    # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    # txt格式点云用open3d可视化
    txt_path = './airplane_0001.txt'
    # 通过numpy读取txt点云
    pcd = np.genfromtxt(txt_path, delimiter=",")
    # 插入x,y,z坐标
    pcd = DataFrame(pcd[:, :3], columns=['x', 'y', 'z'])
    # 加载点坐标
    point = PyntCloud(pcd)
    # 实例化
    mesh = point.to_instance("open3d", mesh=True)
    # 可视化
    o3d.visualization.draw_geometries([mesh])
    # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    # # 快速显示单个点云数据
    # pcd = o3d.io.read_point_cloud("xx.ply")
    # o3d.visualization.draw_geometries([pcd])
    # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    # # 同时显示多个点云数据
    # pcd1 = o3d.io.read_point_cloud("xx1.ply")
    # pcd2 = o3d.io.read_point_cloud("xx2.ply")
    # o3d.visualization.draw_geometries([pcd1, pcd2])
    # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    # # 读取ply并显示
    # pcd = o3d.io.read_point_cloud("xx.ply")
    # vis = o3d.visualization.Visualizer()
    # vis.create_window()
    # # 将点云添加至visualizer
    # vis.add_geometry(pcd)
    # # 让visualizer渲染点云
    # vis.poll_events()
    # vis.update_renderer()
    # vis.run()



if __name__ == "__main__":
    main()
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值