Bambu Studio 发现 xx个开放边

目录

admesh修复

[我现在加载blender标注正方体,水平直接切割,切割完导出glb, Bambu Studio 发现有25条开放边](#我现在加载blender标注正方体,水平直接切割,切割完导出glb, Bambu Studio 发现有25条开放边)

bpy修复:


Bambu Studio 自带修复功能

admesh修复

bash 复制代码
apt install admesh

admesh -b repaired.stl zft_print.stl

我现在加载blender标注正方体,水平直接切割,切割完导出glb, Bambu Studio 发现有25条开放边

bpy修复:

测试效果,会改变物体,不可取

python 复制代码
# fix_model.py - 适配 Blender 5.0+
import bpy, sys

# 解析参数
argv = sys.argv
argv = argv[argv.index("--") + 1:]  # 获取 -- 之后的参数
input_file = argv[0]
output_file = argv[1]
voxel_size = float(argv[2]) if len(argv) > 2 else 0.15
merge_objects = argv[3].lower() == 'true' if len(argv) > 3 else False

print(f"输入: {input_file}")
print(f"输出: {output_file}")
print(f"体素大小: {voxel_size}mm")
print(f"合并物体: {merge_objects}")

# 清空场景
bpy.ops.object.select_all(action='SELECT')
bpy.ops.object.delete()

# 导入 GLB/GLTF
bpy.ops.import_scene.gltf(filepath=input_file)
print(f"导入完成,物体数量: {len(bpy.data.objects)}")

# 确保所有物体都是MESH类型
mesh_objects = [obj for obj in bpy.data.objects if obj.type == 'MESH']
if not mesh_objects:
	raise Exception("没有找到网格物体")

print(f"网格物体数量: {len(mesh_objects)}")

# 如果需要合并所有物体
if merge_objects and len(mesh_objects) > 1:
	# 取消所有选择
	bpy.ops.object.select_all(action='DESELECT')
	# 选择所有网格物体
	for obj in mesh_objects:
		obj.select_set(True)
	# 设置活动物体
	bpy.context.view_layer.objects.active = mesh_objects[0]
	# 合并
	bpy.ops.object.join()
	mesh_objects = [bpy.context.active_object]
	print("物体已合并")

# 对每个网格物体进行Voxel Remesh
for obj in mesh_objects:
	print(f"处理物体: {obj.name}")

	# 取消所有选择
	bpy.ops.object.select_all(action='DESELECT')

	# 选择当前物体
	obj.select_set(True)
	bpy.context.view_layer.objects.active = obj

	# 确保在物体模式
	bpy.ops.object.mode_set(mode='OBJECT')

	# 添加 Remesh 修改器(Voxel)
	mod = obj.modifiers.new(name="VoxelRemesh", type='REMESH')
	mod.mode = 'VOXEL'
	mod.voxel_size = voxel_size
	mod.use_remove_disconnected = False

	# 应用修改器
	bpy.ops.object.modifier_apply(modifier=mod.name)

	# 进入编辑模式,清理顶点
	bpy.ops.object.mode_set(mode='EDIT')
	bpy.ops.mesh.select_all(action='SELECT')
	bpy.ops.mesh.remove_doubles(threshold=0.0001)
	bpy.ops.mesh.normals_make_consistent(inside=False)
	bpy.ops.object.mode_set(mode='OBJECT')

	print(f"  Remesh 完成,顶点数: {len(obj.data.vertices)}")

# 选择所有网格物体用于导出
bpy.ops.object.select_all(action='DESELECT')
for obj in mesh_objects:
	obj.select_set(True)
if mesh_objects:
	bpy.context.view_layer.objects.active = mesh_objects[0]

bpy.ops.wm.stl_export(filepath=output_file)
# 导出为 STL
# bpy.ops.export_mesh.stl(filepath=output_file, use_selection=True, use_mesh_modifiers=True, batch_mode='OBJECT' if len(mesh_objects) > 1 else 'OFF')

print(f"\n✅ Voxel Remesh 完成 → {output_file}")
print(f"   处理了 {len(mesh_objects)} 个物体")
相关推荐
七老板的blog1 小时前
多阶段 AI 评测流水线架构设计与实践
java·人工智能·spring
程序员cxuan1 小时前
Codex 一直 Reconnecting?我最后发现,常见就两个坑
人工智能·后端·程序员
fan65404141 小时前
高端制造行业AI搜索优化服务商选型:技术维度的4个评估标准
人工智能·制造
qq_458148201 小时前
科大讯飞实时语音识别(rtasr)真实项目踩坑经验总结与手把手教学真实可运行Demo
java·开发语言·websocket·语音识别
三品吉他手会点灯1 小时前
C语言学习笔记 - 46.运算符和表达式 - 运算符4 - 对初学运算符的一些建议
c语言·开发语言·笔记·学习
优信其乐1 小时前
2026 PPT讲解视频生成工具易用性排行榜
人工智能·powerpoint·yoco·ppt转视频工具·数字人讲解ppt
逻辑君1 小时前
Foresight研究报告【20260022】
人工智能
泠不丁1 小时前
生活中的温柔科技:基于本地 DeepSeek + 语音识别,给独居父母做一个能陪聊解闷的实体音箱助手
人工智能
创业之路&下一个五年1 小时前
mvvm中v和vm关系,vm中v和m的关系?
java·开发语言·javascript