3d机器学习open3d学习教程4--三角网格对象TriangleMesh

前言

再来整一整另一种3d数据。接着上一节的点云2

1. open3d.geometry.TriangleMesh

和点云一样,三角网格也是3d数据的一种表示open3d.geometry.TriangleMesh实现了三角网格的数据结构,三角形网格包含顶点和由顶点索引表示的三角形。网格也可以包含三角形法线、顶点法线和顶点颜色。

我们再来看一看三角网格对象的一些静态字段:
(1)adjacency_list:顶点的邻接表,adjacency_lis[i]表示与顶点i相邻顶点的索引。
(2)textures:纹理图像
(3)vertices:三角网格的顶点,可以转换为numpy数组访问,shape为(num_vertices,3)
(4)vertex_normals:顶点法线,可以转换为numpy数组访问,shape为(num_vertices,3)
(5)vertex_colors:顶点的rgb颜色,可以转换为numpy数组访问,shape为(num_vertices,3),rgb值范围在[0-1]
(6)triangle_uvs:由构成三角形的点的索引表示的UV列表,可以转换为numpy数组访问,shape为(3 * num_triangles, 2)
(7)triangles:可以转换为numpy数组访问,shape为(num_triangles,3),简答来说每一个其中每一行数据就是一个三角形,如triangles[i]表示一个三角形,其中保存的是三个顶点对应的索引
(8)triangle_normals:三角形法线,可以转换为numpy数组访问,shape为(num_triangles,3)

2.例子

如下代码,我们创建一个球体网格,计算顶点法线:

import open3d as o3d
import numpy as np

mesh = o3d.geometry.TriangleMesh.create_sphere()
mesh.compute_vertex_normals()
print(mesh)
print("顶点:",np.asarray(mesh.vertices))
print("三角形",np.asarray(mesh.triangles))
print("顶点法线:",np.asarray(mesh.vertex_normals))
o3d.visualization.draw_geometries([mesh])

打印结果如下:
打印结果

可视化结果如下:
在这里插入图片描述

下面我们将代码改进一下,将x值大于0顶点渲染成红色,小于0的渲染成蓝色:

import open3d as o3d
import numpy as np

mesh = o3d.geometry.TriangleMesh.create_sphere()
mesh.compute_vertex_normals()
num_vertices=np.asarray(mesh.vertices).shape[0]
print(mesh)
print("顶点:",np.asarray(mesh.vertices))
print("三角形",np.asarray(mesh.triangles))
print("顶点法线:",np.asarray(mesh.vertex_normals))
color=np.zeros((num_vertices,3))
for i in range(num_vertices):
    if np.asarray(mesh.vertices[i])[0]>0:
        color[i,0]=1
    else:
        color[i,2]=1
mesh.vertex_colors=o3d.utility.Vector3dVector(color)
o3d.visualization.draw_geometries([mesh])

其中o3d.utility.Vector3dVector是用于将numpy数组转换成open3d的数据格式。

可视化结果如下:
在这里插入图片描述

  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
3D 0.10.0版本中,`TriangleMesh`类提供了以下方法可以将点云数据转换为三角网格模型: 1. `create_from_point_cloud_poisson`: 使用Poisson重建算法从点云数据创建三角网格模型。 2. `create_from_point_cloud_ball_pivoting`: 使用Ball Pivoting算法从点云数据创建三角网格模型。 3. `create_from_point_cloud_alpha_shape`: 使用alpha形状参数从点云数据创建三角网格模型。 4. `create_from_depth_image`: 从深度图像和相机内参创建三角网格模型。 5. `create_coordinate_frame`: 创建一个三维坐标系的三角网格模型。 6. `create_box`: 从一个边长为1的立方体创建三角网格模型。 7. `create_sphere`: 从一个半径为1的球体创建三角网格模型。 8. `create_cylinder`: 从一个高度为1、半径为1的圆柱体创建三角网格模型。 9. `create_cone`: 从一个高度为1、半径为1的圆锥体创建三角网格模型。 10. `create_torus`: 从一个半径为1、圆环半径为0.25的环面创建三角网格模型。 您可以根据需要选择其中的一个方法将点云数据转换为三角网格模型。例如,使用`create_from_point_cloud_alpha_shape`方法可以按照以下方式将点云数据转换为三角网格模型: ```python import open3d as o3d # 读取点云文件 pcd = o3d.io.read_point_cloud("point_cloud.ply") # 定义alpha形状参数 alpha = 0.1 # 使用alpha形状参数从点云数据创建三角网格模型 bpa_mesh = o3d.geometry.TriangleMesh.create_from_point_cloud_alpha_shape(pcd, alpha) # 显示三角网格模型 o3d.visualization.draw_geometries([bpa_mesh]) ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

追天一方

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

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

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

打赏作者

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

抵扣说明:

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

余额充值