news 2026/6/9 20:09:00

BlobbyLogo 几何体的隐式建模,创建更加平滑的模型

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
BlobbyLogo 几何体的隐式建模,创建更加平滑的模型

一:主要的知识点

1、说明

本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客

2、知识点纪要

本段代码主要涉及的有①vtkImplicitModeller隐式建模


二:代码及注释

import vtkmodules.vtkInteractionStyle import vtkmodules.vtkRenderingOpenGL2 from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkIOLegacy import vtkPolyDataReader from vtkmodules.vtkCommonTransforms import vtkTransform from vtkmodules.vtkFiltersGeneral import vtkTransformPolyDataFilter from vtkmodules.vtkFiltersCore import vtkAppendPolyData, vtkPolyDataNormals, vtkContourFilter from vtkmodules.vtkFiltersHybrid import vtkImplicitModeller from vtkmodules.vtkRenderingCore import ( vtkActor, vtkPolyDataMapper, vtkProperty, vtkRenderWindow, vtkRenderWindowInteractor, vtkRenderer ) def main(): colors = vtkNamedColors() fileName1, fileName2, fileName3 = "Data/v.vtk", "Data/t.vtk", "Data/k.vtk" aRenderer = vtkRenderer() aRenderWindow = vtkRenderWindow() aRenderWindow.AddRenderer(aRenderer) anInteractor = vtkRenderWindowInteractor() anInteractor.SetRenderWindow(aRenderWindow) aRenderWindow.SetSize(300, 300) aRenderWindow.SetWindowName('BlobbyLogo') letterV = vtkPolyDataReader() letterV.SetFileName(fileName1) letterT = vtkPolyDataReader() letterT.SetFileName(fileName2) letterK = vtkPolyDataReader() letterK.SetFileName(fileName3) VTransform = vtkTransform() VTransform.Translate(-16.0, 0.0, 12.5) VTransform.RotateY(40) VTransformFilter = vtkTransformPolyDataFilter() VTransformFilter.SetInputConnection(letterV.GetOutputPort()) VTransformFilter.SetTransform(VTransform) TTransform = vtkTransform() TTransformFilter = vtkTransformPolyDataFilter() TTransformFilter.SetInputConnection(letterT.GetOutputPort()) TTransformFilter.SetTransform(TTransform) KTransform = vtkTransform() KTransform.Translate(14.0, 0.0, 0.0) KTransform.RotateY(-40) KTransformFilter = vtkTransformPolyDataFilter() KTransformFilter.SetInputConnection(letterK.GetOutputPort()) KTransformFilter.SetTransform(KTransform) appendAll = vtkAppendPolyData() appendAll.AddInputConnection(VTransformFilter.GetOutputPort()) appendAll.AddInputConnection(TTransformFilter.GetOutputPort()) appendAll.AddInputConnection(KTransformFilter.GetOutputPort()) logoNormals = vtkPolyDataNormals() logoNormals.SetInputConnection(appendAll.GetOutputPort()) logoNormals.SetFeatureAngle(60) logoMapper = vtkPolyDataMapper() logoMapper.SetInputConnection(logoNormals.GetOutputPort()) logo = vtkActor() logo.SetMapper(logoMapper) # 隐式建模 # vtkImplicitModeller 输入的几何(reader 读出的模型,比如一个 vtkPolyData)转换成一个 隐式函数场 blobbyLogoImp = vtkImplicitModeller() blobbyLogoImp.SetInputConnection(appendAll.GetOutputPort()) """ vtkImplicitModeller 会计算每个体素到输入几何表面的最小距离,但为了性能考虑,不会无限计算 而是如果距离超过 MaximumDistance,就不再计算,直接设为这个最大值 可以理解成:值越大,生成的“模糊边缘(blobby)”越宽,值越小,模型越“紧贴”原始几何 """ blobbyLogoImp.SetMaximumDistance(0.075) blobbyLogoImp.SetSampleDimensions(64, 64, 64) # 表示输出的体数据是一个 64×64×64 的三维网格 blobbyLogoImp.SetAdjustDistance(0.05) # 调整隐式距离的“软化程度”或“平滑边界宽度” 当多个几何靠得很近时,这个参数能让它们“自然融合”成一个连续的体 blobbyLogoIso = vtkContourFilter() blobbyLogoIso.SetInputConnection(blobbyLogoImp.GetOutputPort()) blobbyLogoIso.SetValue(1, 1.5) blobbyLogoMapper = vtkPolyDataMapper() blobbyLogoMapper.SetInputConnection(blobbyLogoIso.GetOutputPort()) blobbyLogoMapper.ScalarVisibilityOff() tomato = vtkProperty() tomato.SetDiffuseColor(colors.GetColor3d('tomato')) tomato.SetSpecular(.3) tomato.SetSpecularPower(20) banana = vtkProperty() banana.SetDiffuseColor(colors.GetColor3d('banana')) banana.SetDiffuse(.7) banana.SetSpecular(.4) banana.SetSpecularPower(20) blobbyLogo = vtkActor() blobbyLogo.SetMapper(blobbyLogoMapper) blobbyLogo.SetProperty(banana) logo.SetProperty(tomato) logo.SetPosition(0, 0, 6) aRenderer.AddActor(logo) aRenderer.AddActor(blobbyLogo) aRenderer.SetBackground(colors.GetColor3d('SlateGray')) aRenderWindow.Render() anInteractor.Start() if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 13:30:01

零基础入门:用预装镜像快速搭建你的第一个Z-Image二次开发环境

零基础入门:用预装镜像快速搭建你的第一个Z-Image二次开发环境 如果你是一名刚接触AI开发的大学生,想要基于Z-Image-Turbo进行课程项目开发,却被Python环境配置和依赖管理搞得焦头烂额,那么这篇文章正是为你准备的。本文将带你使用…

作者头像 李华
网站建设 2026/6/10 13:30:21

终极DLC解锁指南:3步实现全平台自动化解锁

终极DLC解锁指南:3步实现全平台自动化解锁 【免费下载链接】CreamApi 项目地址: https://gitcode.com/gh_mirrors/cr/CreamApi 还在为游戏DLC内容无法完整体验而苦恼吗?CreamApi作为一款革命性的自动化解锁工具,让零基础玩家也能轻松…

作者头像 李华
网站建设 2026/6/10 13:32:44

从被动拦截到主动降维:AURA 开启 AI 知识资产防护新纪元

一、引言:AI时代知识图谱的“攻防战”进入深水区 随着大语言模型(LLM)与知识图谱(KG)的深度融合,GraphRAG技术已成为企业构建核心竞争力的关键支撑——从金融行业的智能风控、医疗领域的临床决策&#xff0…

作者头像 李华
网站建设 2026/6/10 14:35:50

如何高效使用Magicodes.IE:.NET数据处理的完整解决方案

如何高效使用Magicodes.IE:.NET数据处理的完整解决方案 【免费下载链接】Magicodes.IE 项目地址: https://gitcode.com/gh_mirrors/mag/Magicodes.IE 在.NET开发中,数据导入导出是每个项目都无法回避的核心需求。Magicodes.IE作为一个强大的数据…

作者头像 李华
网站建设 2026/6/7 16:56:37

轻量级OCR部署实践:自动预处理+高精度识别全流程

轻量级OCR部署实践:自动预处理高精度识别全流程 📖 技术背景与核心挑战 光学字符识别(OCR)作为连接物理世界与数字信息的关键桥梁,广泛应用于文档数字化、票据识别、车牌提取、工业质检等场景。然而,在真实…

作者头像 李华
网站建设 2026/6/10 15:35:00

CRNN模型在医疗影像报告识别中的应用

CRNN模型在医疗影像报告识别中的应用 📖 项目背景:OCR技术在医疗场景中的关键价值 随着电子病历系统(EMR)和医学影像归档与通信系统(PACS)的普及,医疗机构积累了海量的非结构化数据——其中&…

作者头像 李华