open3d python 由索引提取点云

话不多说,直接上代码:

import open3d as o3d
import numpy as np

pcd = o3d.io.read_point_cloud("rabbit.pcd")
f = open('temp.txt', 'r')
lines = f.readlines()
f.close()
for line in lines:
    result = np.array(list(map(int, line.split(','))))  # 字符串分割后转为数组

def display_inlier_outlier(cloud, ind):
    inlier_cloud = cloud.select_by_index(ind)
    outlier_cloud = cloud.select_by_index(ind, invert=True) # 设置为True表示保存ind之外的点
    print("Showing outliers (red) and inliers : ")
    outlier_cloud.paint_uniform_color([0, 1, 0])
    inlier_cloud.paint_uniform_color([1, 0, 0])
    o3d.visualization.draw_geometries([inlier_cloud, outlier_cloud],width=600,height=600)


display_inlier_outlier(pcd, result)

rabbit.pcd 文件为斯坦福兔子,在网上有的下载

temp.txt 文件为想提取的点云索引,如下:

运行结果:

参考文章:

Open3D 根据索引提取点云

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值