当前位置: 首页 > news >正文

【Python-Open3D学习笔记】005Mesh相关方法

TriangleMesh相关方法

文章目录

  • TriangleMesh相关方法
    • 1. 查看mesh三角形面信息
    • 2. 可视化三角形
    • 3. 上采样
    • 4. 计算mesh形成的面积和体积

1. 查看mesh三角形面信息

def view_hull_triangles(hull: o3d.geometry.TriangleMesh):"""查看mesh三角形面信息(顶点索引、顶点坐标):param hull::return:"""# 获取三角形的顶点索引triangles = np.asarray(hull.triangles)  # 每个三角形由三个顶点的索引组成# 获取顶点坐标vertices = np.asarray(hull.vertices)  # 所有顶点的坐标print(f"总共有 {len(triangles)} 个三角形面")for i, triangle in enumerate(triangles):print(f"三角形 {i + 1}: 顶点索引 {triangle}, 顶点坐标:")for idx in triangle:print(f"  顶点 {idx}: {vertices[idx]}")return triangles, vertices

2. 可视化三角形

def highlight_triangle(hull: o3d.geometry.TriangleMesh, triangle_idx: int):"""可视化单个三角形:param hull::param triangle_idx::return:"""# 获取三角形索引triangles = np.asarray(hull.triangles)vertices = np.asarray(hull.vertices)# 获取特定三角形的顶点triangle = triangles[triangle_idx]triangle_vertices = vertices[triangle]# 创建一个新点云,表示高亮的三角形highlight = o3d.geometry.TriangleMesh()highlight.vertices = o3d.utility.Vector3dVector(triangle_vertices)highlight.triangles = o3d.utility.Vector3iVector([[0, 1, 2]])highlight.paint_uniform_color([1, 0, 0])  # 高亮颜色:红色# 绘制原始凸包和高亮三角形o3d.visualization.draw_geometries([hull, highlight], window_name="Highlight Triangle")
def highlight_all_triangles(hull: o3d.geometry.TriangleMesh, show=False):"""可视化所有三角形:param hull::param show: 是否直接显示:return:"""# 获取三角形索引和顶点坐标triangles = np.asarray(hull.triangles)vertices = np.asarray(hull.vertices)# 创建一个新三角网格,用于高亮显示highlight_mesh = o3d.geometry.TriangleMesh()# 存储所有高亮的顶点和三角形all_highlighted_vertices = []all_highlighted_triangles = []colors = []for i, triangle in enumerate(triangles):# 获取三角形顶点triangle_vertices = vertices[triangle]# 偏移索引(因为顶点需要连续编号)base_index = len(all_highlighted_vertices)# 添加当前三角形的顶点all_highlighted_vertices.extend(triangle_vertices)# 添加当前三角形的索引(注意偏移)all_highlighted_triangles.append([base_index, base_index + 1, base_index + 2])# 为每个三角形分配随机颜色random_color = np.random.rand(3)  # RGB 随机颜色colors.append(random_color)# 设置高亮网格的顶点、三角形和颜色highlight_mesh.vertices = o3d.utility.Vector3dVector(all_highlighted_vertices)highlight_mesh.triangles = o3d.utility.Vector3iVector(all_highlighted_triangles)highlight_mesh.vertex_colors = o3d.utility.Vector3dVector(np.repeat(colors, 3, axis=0)  # 每个顶点与其三角形共享同样的颜色)# 绘制原始凸包和高亮网格# o3d.visualization.draw_geometries([hull, highlight_mesh], window_name="Highlight All Triangles")if show:o3d.visualization.draw_geometries([highlight_mesh], window_name="Highlight All Triangles")return highlight_mesh

显示效果:

在这里插入图片描述

3. 上采样

def upsample_by_mesh(mesh: o3d.geometry.TriangleMesh, number_of_points: int = 10000):"""通过mesh进行上采样:param mesh::param number_of_points::return:"""dense_pcd = mesh.sample_points_uniformly(number_of_points=number_of_points)return dense_pcd

原始数据:

在这里插入图片描述

上采样后:

在这里插入图片描述

4. 计算mesh形成的面积和体积

def calculate_hull_metrics(hull: o3d.geometry.TriangleMesh):surface_area = 0volume = 0try:if not hull.is_watertight():# print("网格不是水密的!尝试简化修复")hull = hull.simplify_quadric_decimation(target_number_of_triangles=1000)# print("网格是水密的!")# 计算表面积surface_area = hull.get_surface_area()# 计算体积volume = hull.get_volume()return surface_area, volumeexcept Exception as e:print(f"Error occurred: {str(e)}")return surface_area, volume
http://www.lryc.cn/news/494350.html

相关文章:

  • js原型、原型链和继承
  • 团队自创【国王的魔镜-2】
  • c++编程玩转物联网:使用芯片控制8个LED实现流水灯技术分享
  • 【Jenkins】docker 部署 Jenkins 踩坑笔记
  • Unreal Engine使用Groom 打包后报错
  • 嵌入式QT学习第3天:UI设计器的简单使用
  • 【连接池】.NET开源 ORM 框架 SqlSugar 系列
  • 图论入门编程
  • 在Java中使用Apache POI导入导出Excel(三)
  • UR开始打中国牌,重磅发布国产化协作机器人UR7e 和 UR12e
  • FRU文件
  • AI需求条目化全面升级!支持多格式需求,打破模板限制!
  • Java—I/O流
  • Huginn服务部署
  • 深入解析Java数据包装类型:特性、机制与最佳实践
  • 【Java基础入门篇】二、控制语句和递归算法
  • PostgreSQL WAL日志膨胀处理
  • 用户该怎么管理维护自己的服务器?
  • 【MYSQL数据库相关知识介绍】
  • 初窥 HTTP 缓存
  • yolov8的深度学习环境安装(cuda12.4、ubuntu22.04)
  • RSA算法和AES算法,哪种更安全
  • Vue教程|搭建vue项目|Vue-CLI新版脚手架
  • kdump调试分析(适用于麒麟,ubuntu等OS)
  • houdini肌肉刷pin点的方法
  • JMeter 并发策略-针对准点秒杀场景的压测实现
  • 龙迅#LT6912适用于HDMI2.0转HDMI+LVDS/MIPI,分辨率高达4K60HZ,支持音频和HDCP2.2
  • RBF神经网络预测结合NSGAII多目标优化
  • 如何看linux系统内核是aarch64 ,还是64-bit
  • 如何通过 ADB 安装 xapk