news 2026/1/18 9:31:54

FilledPolygon切割一个三维模型并用颜色填充其横截面

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
FilledPolygon切割一个三维模型并用颜色填充其横截面

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①切割模型并用颜色填充横截面


二:代码及注释

import vtkmodules.vtkRenderingOpenGL2 from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkCommonDataModel import vtkPlane, vtkPolyData from vtkmodules.vtkFiltersSources import vtkSphereSource from vtkmodules.vtkFiltersCore import vtkCutter, vtkFeatureEdges, vtkStripper from vtkmodules.vtkRenderingCore import ( vtkActor, vtkPolyDataMapper, vtkProperty, vtkRenderWindow, vtkRenderWindowInteractor, vtkRenderer ) def main(): colors = vtkNamedColors() sphere = vtkSphereSource() sphere.SetRadius(50) sphere.SetThetaResolution(100) sphere.SetPhiResolution(100) # cubeMapper = vtkPolyDataMapper() # cubeMapper.SetInputConnection(cube.GetOutputPort()) plane = vtkPlane() plane.SetOrigin(20, 0, 0) plane.SetNormal(1, 0, 0) cutter = vtkCutter() cutter.SetCutFunction(plane) cutter.SetInputConnection(sphere.GetOutputPort()) cutter.Update() # FeatureEdges = vtkFeatureEdges() # FeatureEdges.SetInputConnection(cutter.GetOutputPort()) # FeatureEdges.BoundaryEdgesOn() # FeatureEdges.FeatureEdgesOff() # FeatureEdges.ManifoldEdgesOff() # FeatureEdges.NonManifoldEdgesOff() # FeatureEdges.Update() cutStrips = vtkStripper() cutStrips.SetInputConnection(cutter.GetOutputPort()) cutStrips.Update() cutPoly = vtkPolyData() cutPoly.SetPoints(cutStrips.GetOutput().GetPoints()) cutPoly.SetPolys(cutStrips.GetOutput().GetLines()) cutMapper = vtkPolyDataMapper() cutMapper.SetInputData(cutPoly) backface = vtkProperty() backface.SetColor(colors.GetColor3d('Gold')) cutActor = vtkActor() cutActor.SetMapper(cutMapper) cutActor.GetProperty().SetColor(colors.GetColor3d('Yellow')) cutActor.GetProperty().SetEdgeColor(colors.GetColor3d('Red')) cutActor.GetProperty().SetLineWidth(2) cutActor.GetProperty().EdgeVisibilityOn() # cutActor.GetProperty().SetOpacity(0.7) cutActor.SetBackfaceProperty(backface) ren = vtkRenderer() ren.AddActor(cutActor) # Add renderer to renderwindow and render renWin = vtkRenderWindow() renWin.AddRenderer(ren) renWin.SetSize(600, 400) renWin.SetWindowName('FilledPolygon') iren = vtkRenderWindowInteractor() iren.SetRenderWindow(renWin) ren.SetBackground(colors.GetColor3d('DarkSlateGray')) ren.GetActiveCamera().SetPosition(223, -122, -91) renWin.Render() camera = ren.GetActiveCamera() camera.SetPosition(151.519511, 12.795117, -223.586044) camera.SetFocalPoint(12.518283, 1.963242, 7.618042) camera.SetViewUp(0.740690, -0.523767, 0.420769) camera.SetDistance(269.988889) camera.SetClippingRange(175.347580, 366.490816) camera.Zoom(1.5) iren.Start() if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/17 16:35:14

Glyph2D 同一个图形根据点云的输入产生不同位置的输出

一:主要的知识点 1、说明 本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客 2、知识点纪要 本段代码主要涉及的有①同时生成多个坐标的相同模型,…

作者头像 李华
网站建设 2026/1/8 9:51:40

Lombok 注解:简化 Java 代码

目录一、深入理解 Lombok 注解:简化 Java 代码的利器二、Lombok 简介1、安装 Lombok1、Maven2、Gradle二、常用 Lombok 注解及示例1. Getter 和 Setter2. ToString3. EqualsAndHashCode4. NoArgsConstructor、RequiredArgsConstructor 和 AllArgsConstructor5. Data…

作者头像 李华
网站建设 2026/1/17 1:15:59

别让大数据“全表扫描”掏空你:数据分区策略与分区裁剪的实战心经

别让大数据“全表扫描”掏空你:数据分区策略与分区裁剪的实战心经 大家好,我是 Echo_Wish。今天不聊那些高屋建瓴的框架宣传,我们来点接地气的——数据分区策略怎么做才有效?分区裁剪怎么让查询跑得飞? 这话题其实特别…

作者头像 李华
网站建设 2026/1/15 19:45:51

(转载)真正的缘分,“推背感”都跟强

这个推背感就是:除了这个,其余没得选。 讲个真实故事。 有个前同事,在广告行业混了八年,前年公司裁员,他是第一批走的。原以为凭资历很快能找到下家,结果投了上百份简历,只有三家小公司给了面…

作者头像 李华
网站建设 2026/1/15 22:01:07

Hadoop生态下的数据预处理:MapReduce实战案例解析

Hadoop生态下的数据预处理:从理论到MapReduce实战的完整指南 一、引言:为什么数据预处理是大数据分析的“地基”? 你是否遇到过这样的场景? 拿到一份TB级的电商用户行为日志,却发现里面混着缺失关键字段的记录(比如没有用户ID)、格式混乱的时间戳(比如1620000000000)…

作者头像 李华