news 2026/5/1 7:58:11

ExtractPolyLinesFromPolyData切割一个三维模型(球体),并可视化切割后产生的多条等高线

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ExtractPolyLinesFromPolyData切割一个三维模型(球体),并可视化切割后产生的多条等高线

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①着色方式,②vtkStripper的作用


二:代码及注释

import vtkmodules.vtkRenderingOpenGL2 from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkCommonCore import vtkIdList from vtkmodules.vtkCommonDataModel import vtkPlane from vtkmodules.vtkFiltersCore import vtkCutter, vtkStripper from vtkmodules.vtkFiltersSources import vtkSphereSource from vtkmodules.vtkRenderingCore import ( vtkActor, vtkPolyDataMapper, vtkRenderWindow, vtkRenderWindowInteractor, vtkRenderer ) def main(): colors = vtkNamedColors() lineColor = colors.GetColor3d("peacock") modeColor = colors.GetColor3d("silver") backgroundColor = colors.GetColor3d("wheat") modelSource = vtkSphereSource() plane = vtkPlane() cutter = vtkCutter() cutter.SetCutFunction(plane) cutter.SetInputConnection(modelSource.GetOutputPort()) """ cutter如何去切取决去vtkPlane设置的平面的法向量 如果设置的平面的法向量为(0,0,1) 则表示切割球体的平面为平行于XY平面。 -0.5, 0.5表示这个平面从-0.5的z值高度,沿着法向量的方向一直移动到0.5,中间取10个值 """ cutter.GenerateValues(10, -0.5, 0.5) modelMapper = vtkPolyDataMapper() modelMapper.SetInputConnection(modelSource.GetOutputPort()) model = vtkActor() model.SetMapper(modelMapper) model.GetProperty().SetDiffuseColor(modeColor) """ SetInterpolationToFlat 将模型的着色方式设置为平面着色 当启用平面着色时,VTK 会对每个多边形(如三角形或四边形)使用一个单一的、统一的颜色来填充。这意味着: 着色(Shading):每个面片的颜色是恒定的,从一个顶点到另一个顶点不会有渐变。 光照(Lighting):光照计算只会在每个面片的中心进行一次,然后整个面片都用这个颜色来渲染。 """ model.GetProperty().SetInterpolationToFlat() """ vtkStripper 的作用是把 线段或三角形片元 按照拓扑关系合并成更长的 polyline(折线)或 triangle strip(三角带)。 没有 vtkStripper 的话,vtkCutter 切出来的结果可能是一堆独立的小线段。 加上 vtkStripper,这些小线段如果端点连续,就会被自动拼接成更长的线条,更利于渲染或后续处理 """ stripper = vtkStripper() stripper.SetInputConnection(cutter.GetOutputPort()) """ JoinContiguousSegmentsOn 决定 vtkStripper 是否把 首尾相接的线段 """ stripper.JoinContiguousSegmentsOn() linesMapper = vtkPolyDataMapper() linesMapper.SetInputConnection(stripper.GetOutputPort()) lines = vtkActor() lines.SetMapper(linesMapper) lines.GetProperty().SetDiffuseColor(lineColor) lines.GetProperty().SetLineWidth(3.) renderer = vtkRenderer() renderWindow = vtkRenderWindow() renderWindow.AddRenderer(renderer) renderWindow.SetSize(640, 480) renderWindow.SetWindowName('ExtractPolyLinesFromPolyData') interactor = vtkRenderWindowInteractor() interactor.SetRenderWindow(renderWindow) # Add the actors to the renderer. renderer.AddActor(model) renderer.AddActor(lines) renderer.SetBackground(backgroundColor) renderer.GetActiveCamera().Azimuth(-45) renderer.GetActiveCamera().Elevation(-22.5) renderer.ResetCamera() # This starts the event loop and as a side effect causes an # initial render. renderWindow.Render() interactor.Start() # 获取线条的数目 numberOfLines = cutter.GetOutput().GetNumberOfLines() print('-----------Lines without using vtkStripper') print('There are {0} lines in the polydata'.format(numberOfLines)) numberOfLines = stripper.GetOutput().GetNumberOfLines() points = stripper.GetOutput().GetPoints() cells = stripper.GetOutput().GetLines() cells.InitTraversal() # 重置遍历器,将内部的迭代器指针移到第一个单元的位置 print('-----------Lines using vtkStripper') print('There are {0} lines in the polydata'.format(numberOfLines)) indices = vtkIdList() lineCount = 0 while cells.GetNextCell(indices): # 类比于for cell in cells: # indices 里现在就是当前 cell 的点索引 print('Line {0}:'.format(lineCount)) for i in range(indices.GetNumberOfIds()): point = points.GetPoint(indices.GetId(i)) print('\t({0:0.6f} ,{1:0.6f}, {2:0.6f})'.format(point[0], point[1], point[2])) lineCount += 1 if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 17:03:32

AI搜索排名GEO优化行业研究报告

AI搜索排名GEO优化行业研究报告引言随着人工智能技术的飞速发展,搜索引擎优化(SEO)已经从传统的关键词优化、内容优化逐渐演进到更复杂的地理定位优化(GEO)。GEO优化不仅能够提升网站在本地搜索中的可见性,…

作者头像 李华
网站建设 2026/5/1 6:08:52

基于Golang的分布式综合资产管理系统设计与实现

基于Golang的分布式综合资产管理系统设计与实现 基于Golang的分布式综合资产管理系统:毕业设计源码与论文全解析 引言:网络安全时代的高效资产管理利器 在当今数字化时代,网络安全已成为企业和组织面临的核心挑战之一。随着网络攻击手段的…

作者头像 李华
网站建设 2026/4/18 9:22:14

GB/T 4857.23医疗器械运输包装振动验证关键要点

医疗器械、生物制品及医药产品在运输过程中面临各种环境应力,其中振动是导致产品失效的主要因素之一。据行业统计,约35%的医疗产品运输损坏源于振动和冲击,尤其是高精度诊断设备、植入器械、生物制剂和疫苗等高价值、高敏感性产品。垂直随机振…

作者头像 李华
网站建设 2026/5/1 6:15:56

Bypass Paywalls Clean终极指南:轻松绕过付费墙的5种简单方法

还在为付费墙阻挡而烦恼吗?😤 Bypass Paywalls Clean曾经是Chrome浏览器上最受欢迎的付费墙绕过扩展,但由于DMCA下架通知已不再在GitHub上托管。不过别担心!今天我将为您揭秘5种简单有效的替代方案,让您轻松享受免费阅…

作者头像 李华
网站建设 2026/4/28 16:17:45

智能的二象性与世界的二象性

智能的二象性与人机协同对世界二象性的关联,本质上是人类认知范式与机器逻辑在复杂系统中的深度融合。这种关联不仅体现在技术层面,更涉及哲学、认知科学和复杂系统理论的交叉。下面将简单地从智能二象性的内涵、世界二象性的映射、人机协同的关联机制三…

作者头像 李华
网站建设 2026/4/30 2:54:48

EmotiVoice语音合成引擎的安全启动机制设计

EmotiVoice语音合成引擎的安全启动机制设计 在智能语音助手、虚拟偶像和个性化客服日益普及的今天,用户不再满足于“能说话”的机器,而是期待听到带有情感起伏、语气自然、音色真实的人类级语音。EmotiVoice正是在这一背景下脱颖而出的开源TTS引擎——它…

作者头像 李华