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

python:trimesh 用于 STL 文件解析和 3D 操作

python:trimesh 是一个用于处理三维模型的库,支持多种格式的导入导出,比如STL、OBJ等,还包含网格操作、几何计算等功能。

Python Trimesh 库使用指南

安装依赖库
pip install trimesh
Downloading trimesh-4.6.8-py3-none-any.whl (709 kB)

pip install pyglet==1.5.27
Downloading pyglet-1.5.27-py3-none-any.whl (1.1 MB)

pip show trimesh
Summary: Import, export, process, analyze and view triangular meshes. (三角网格)
Home-page: https://github.com/mikedh/trimesh

pip show pyglet
Summary: Cross-platform windowing and multimedia library
Home-page: http://pyglet.readthedocs.org/en/latest/

加载三维模型并显示

通过 trimesh 可以轻松加载和显示三维模型文件。以下是实现这一功能的示例代码:

import trimesh# 加载一个 STL 文件作为示例
mesh = trimesh.load('example_model.stl')# 显示模型
mesh.show()

此代码片段展示了如何加载 .stl 格式的三维模型,并调用其内置方法来可视化它。
在这里插入图片描述


输出顶点 (Vertices) 和面片 (Faces)

为了获取模型的几何数据,可以访问 verticesfaces 属性。这些属性分别表示模型的所有顶点坐标以及定义三角形面片的索引列表。

import trimesh# 加载模型
mesh = trimesh.load('example_model.obj', process=False)# 获取 vertices 和 faces 数据
print("Vertices:", mesh.vertices[:5])  # 打印前五个顶点
print("Faces:", mesh.faces[:5])        # 打印前五个面片

这段代码演示了如何读取模型中的顶点和面片信息。


将 Vertices 和 Faces 转化为模型

如果已经拥有了顶点和面片的数据,则可以通过它们创建一个新的网格对象。

import trimesh# 定义一些简单的顶点和面片
vertices = [[0, 0, 0],[1, 0, 0],[1, 1, 0],[0, 1, 0]
]faces = [[0, 1, 2],[2, 3, 0]
]# 创建新的 Mesh 对象
new_mesh = trimesh.Trimesh(vertices=vertices, faces=faces)# 显示新生成的模型
new_mesh.show()

以上代码说明了如何手动构建一个由指定顶点和面片组成的简单平面矩形网格。


表面采样与计算最近点

对于某些应用来说,可能需要从现有模型表面上随机抽取样本或者找到某个空间位置最接近的点。

import trimesh# 加载模型
mesh = trimesh.load('example_model.ply')# 随机采样表面点
samples, face_indices = mesh.sample(1000, return_index=True)# 计算给定点到模型的距离及其对应的最近点
point_to_check = np.array([0.5, 0.5, 0])
nearest_distance, nearest_point, _ = mesh.nearest.on_surface(point_to_check)print(f"Nearest Point: {nearest_point}")
print(f"Distance to Nearest Point: {nearest_distance:.4f}")

这里提供了两种常用的操作:一是基于数量参数对目标物体进行均匀分布抽样;二是查询任意一点相对于整个形状的位置关系。


使用齐次变换矩阵修改网格姿态

当涉及到旋转、平移或其他仿射变化时,可以直接利用四维形式表达出来的转换矩阵作用于原始结构之上完成调整动作。

import trimesh
from scipy.spatial.transform import Rotation as R# 初始化一个单位立方体
cube = trimesh.creation.box()# 构造一个绕 Z 轴转 90° 的旋转实例
rotation_vector = [0, 0, np.pi / 2]
rot_matrix = R.from_rotvec(rotation_vector).as_matrix()# 添加额外的一列零向量构成完整的齐次变换阵列
transform_matrix = np.eye(4)
transform_matrix[:3, :3] = rot_matrix# 施加变换至原图元上
transformed_cube = cube.copy().apply_transform(transform_matrix)# 渲染结果对比查看效果差异
scene = trimesh.Scene([cube, transformed_cube])
scene.show()

上述脚本实现了围绕特定轴线执行角度偏移的功能,并且能够直观地观察前后状态之间的区别。


相关文章:

  • 《用MATLAB玩转游戏开发》Flappy Bird:小鸟飞行大战MATLAB趣味实现
  • 【Leetcode 每日一题】1550. 存在连续三个奇数的数组
  • android-ndk开发(12): 获取ndk内置clang的版本详情
  • spark-Schema 定义字段强类型和弱类型
  • TCP/IP 模型每层的封装格式
  • leetcode 15. 三数之和
  • 【25软考网工】第六章(3)数字签名和数字证书
  • 在C++中,符号位是否参与位运算
  • 使用vue3-seamless-scroll实现列表自动滚动播放
  • 【通讯录教程】如何将号码快速导入手机通讯录,支持苹果和安卓手机,一次性导入大量号码进入手机通讯录,基于WPF的解决方案
  • 实战项目5(08)
  • 1688 API 自动化采集实践:商品详情实时数据接口开发与优化
  • 每日c/c++题 备战蓝桥杯(洛谷P1115 最大子段和)
  • 滑动窗口——将x减到0的最小操作数
  • 自然语言处理NLP中的连续词袋(Continuous bag of words,CBOW)方法、优势、作用和程序举例
  • 嵌入式硬件篇---IIC
  • Linux:43线程封装与互斥lesson31
  • upload-labs靶场通关详解:第五关
  • RAII是什么?
  • 9.1.领域驱动设计
  • 美国拟向阿联酋和沙特AI公司出口数十万枚芯片
  • 对话郑永年:我们谈判也是为世界争公义
  • 干部任职公示:陕西宁强、镇安两县县长拟进一步使用
  • 外交部就习近平主席将出席中拉论坛第四届部长级会议开幕式介绍情况
  • 首映丨纪录电影《滚烫年华》:献给所有奋斗者
  • 重庆大学:对学术不端行为“零容忍”,发现一例、查处一例