ExtractLargestIsosurface 提取最大连通域

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①vtkPolyDataConnectivityFilter提取最大连通域的使用

二:代码及注释

python 复制代码
import vtkmodules.vtkRenderingOpenGL2
from vtkmodules.vtkCommonColor import vtkNamedColors
from vtkmodules.vtkFiltersCore import vtkFlyingEdges3D, vtkMarchingCubes, vtkPolyDataConnectivityFilter
from vtkmodules.vtkIOLegacy import vtkStructuredPointsReader
from vtkmodules.vtkRenderingCore import (
    vtkActor,
    vtkPolyDataMapper,
    vtkProperty,
    vtkRenderWindow,
    vtkRenderWindowInteractor,
    vtkRenderer
)
 
 
def main():
    colors = vtkNamedColors()
    colors.SetColor('SkinColor', [240, 184, 160, 255])
    colors.SetColor('BackfaceColor', [255, 229, 200, 255])
    colors.SetColor('BkgColor', [51, 77, 102, 255])
 
    file_name = "Data/brain.vtk"
    threshold = 50
    largest_surface = False  # 是否提取最大连通域
    use_flying_edges = True
 
    reader = vtkStructuredPointsReader()
    reader.SetFileName(file_name)
    reader.Update()
 
    if use_flying_edges:
        mc = vtkFlyingEdges3D()
    else:
        mc = vtkMarchingCubes()
 
    mc.SetInputConnection(reader.GetOutputPort())
    mc.ComputeNormalsOff()
    mc.ComputeGradientsOn()
    mc.SetValue(0, threshold)
 
    confilter = vtkPolyDataConnectivityFilter()
    confilter.SetInputConnection(mc.GetOutputPort())
    confilter.SetExtractionModeToLargestRegion()
 
    mapper = vtkPolyDataMapper()
    mapper.SetInputConnection(confilter.GetOutputPort())
    mapper.ScalarVisibilityOff()
 
    actor = vtkActor()
    actor.GetProperty().SetColor(colors.GetColor3d('SkinColor'))
    back_prop = vtkProperty()
    back_prop.SetDiffuseColor(colors.GetColor3d('BackfaceColor'))
    actor.SetBackfaceProperty(back_prop)
    actor.SetMapper(mapper)
 
    renderer = vtkRenderer()
    renderer.AddActor(actor)
    renderer.SetBackground(colors.GetColor3d('SlateGray'))
    renderer.GetActiveCamera().SetViewUp(0.0, 0.0, 1.0)
    renderer.GetActiveCamera().SetPosition(0.0, 1.0, 0.0)
    renderer.GetActiveCamera().SetFocalPoint(0.0, 0.0, 0.0)
    renderer.ResetCamera()
    renderer.GetActiveCamera().Azimuth(30.0)
    renderer.GetActiveCamera().Elevation(30.0)
    ren_win = vtkRenderWindow()
    ren_win.AddRenderer(renderer)
    ren_win.SetSize(640, 480)
    ren_win.SetWindowName('ExtractLargestIsosurface')
 
    iren = vtkRenderWindowInteractor()
    iren.SetRenderWindow(ren_win)
    ren_win.Render()
    iren.Initialize()
    iren.Start()
 
 
if __name__ == '__main__':
    main()
相关推荐
研究点啥好呢6 小时前
3月22日GitHub热门项目推荐|网页浏览,何须手动
人工智能·python·开源·github
三块可乐两块冰6 小时前
【机器学习笔记三十二】机器学习三十二
python
love530love6 小时前
ComfyUI-3D-Pack:Windows 下手动编译 mesh_inpaint_processor C++ 加速模块
c++·人工智能·windows·python·3d·hunyuan3d·comfyui-3d-pack
vx_biyesheji00016 小时前
计算机毕业设计:Python多源新闻数据智能舆情挖掘平台 Flask框架 爬虫 SnowNLP ARIMA 可视化 数据分析 大数据(建议收藏)✅
爬虫·python·机器学习·数据分析·django·flask·课程设计
m0_587958956 小时前
机器学习与人工智能
jvm·数据库·python
2501_908329856 小时前
Python入门:从零到一的第一个程序
jvm·数据库·python
紫丁香6 小时前
Selenium自动化测试详解1
python·selenium·测试工具·ui
Liu628886 小时前
Web开发与API
jvm·数据库·python
观书喜夜长6 小时前
大模型应用开发学习-基于langchain框架做一个个人文档问答助手
python·学习·idea
m0_743470376 小时前
Python字典与集合:高效数据管理的艺术
jvm·数据库·python