ContourTriangulator从一个PNG图像中提取2D等值线(isoline)

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①等值面提取,②多重采样的含义

二:代码及注释

python 复制代码
import vtkmodules.vtkRenderingOpenGL2
from vtkmodules.vtkCommonColor import vtkNamedColors
from vtkmodules.vtkFiltersCore import vtkMarchingSquares
from vtkmodules.vtkFiltersGeneral import vtkContourTriangulator
from vtkmodules.vtkIOImage import vtkPNGReader
from vtkmodules.vtkRenderingCore import vtkActor, vtkDataSetMapper, vtkRenderWindow, vtkRenderWindowInteractor, \
    vtkRenderer
 
def main():
    file_name = 'Data/fullhead15.png'
    iso_value = 500
    colors = vtkNamedColors()
 
    reader = vtkPNGReader()
    reader.SetFileName(file_name)
    reader.Update()
 
    iso = vtkMarchingSquares()
    iso.SetInputConnection(reader.GetOutputPort())
    """
    0表示等值线的索引,vtkMarchingSquares 可以同时提取多条不同数值的等值线
    iso_value 就是图像里像素值 = 500 的位置所形成的等值线
    """
    iso.SetValue(0, iso_value)
 
    iso_mapper = vtkDataSetMapper()
    iso_mapper.SetInputConnection(iso.GetOutputPort())
    iso_mapper.ScalarVisibilityOff()
 
    iso_actor = vtkActor()
    iso_actor.SetMapper(iso_mapper)
    iso_actor.GetProperty().SetColor(colors.GetColor3d("MediumOrchid"))
 
    poly = vtkContourTriangulator()
    poly.SetInputConnection(iso.GetOutputPort())
 
    poly_mapper = vtkDataSetMapper()
    poly_mapper.SetInputConnection(poly.GetOutputPort())
    poly_mapper.ScalarVisibilityOff()
 
    poly_actor = vtkActor()
    poly_actor.SetMapper(poly_mapper)
    poly_actor.GetProperty().SetColor(colors.GetColor3d("Gray"))
 
 
    renderer = vtkRenderer()
    ren_win = vtkRenderWindow()
    """
    SetMultiSamples  关闭多重采样
    在 OpenGL 渲染里,多重采样抗锯齿 (MSAA) 会让边缘更平滑,看起来不那么锯齿化。
    默认情况下,vtkRenderWindow 可能会打开多重采样(比如 8x)。
    这会增加计算量,有时候也会导致绘制一些特殊几何体(比如透明对象、点云、线框)时出现问题
    SetMultiSamples(0) 的含义
    0 = 关闭多重采样 → 没有抗锯齿(速度快,但可能有锯齿)。
    >0 = 设置多重采样的采样数,比如 4 表示 4x MSAA。
    """
    ren_win.SetMultiSamples(0)
 
    ren_win.AddRenderer(renderer)
    ren_win.SetWindowName('ContourTriangulator')
 
    iren = vtkRenderWindowInteractor()
    iren.SetRenderWindow(ren_win)
 
    renderer.AddActor(poly_actor)
    renderer.AddActor(iso_actor)
    renderer.SetBackground(colors.GetColor3d('DarkSlateGray'))
    ren_win.SetSize(300, 300)
 
    camera = renderer.GetActiveCamera()
    renderer.ResetCamera()
    camera.Azimuth(180)
 
    ren_win.Render()
    iren.Initialize()
    iren.Start()
 
 
if __name__ == '__main__':
    main()
相关推荐
网安墨雨7 分钟前
Python自动化一------pytes与allure结合生成测试报告
开发语言·自动化测试·软件测试·python·职场和发展·自动化
powerfulhell15 分钟前
寒假python作业5
java·前端·python
铉铉这波能秀22 分钟前
LeetCode Hot100 中 enumerate 函数的妙用(2026.2月版)
数据结构·python·算法·leetcode·职场和发展·开发
毕设源码-赖学姐24 分钟前
【开题答辩全过程】以 基于python的电影推荐系统为例,包含答辩的问题和答案
开发语言·python
敲键盘的生活26 分钟前
MoneyPrinter重构之一:用nicegui调用大模型生成视频文案
python·重构·aigc·ai编程·ai写作
小邓睡不饱耶28 分钟前
2026 CSDN榜单封神!3大热门技术+5个大厂案例,新手也能直接抄作业
python·ai
南极星100532 分钟前
我的创作纪念日--128天
java·python·opencv·职场和发展
码界筑梦坊33 分钟前
327-基于Django的兰州空气质量大数据可视化分析系统
python·信息可视化·数据分析·django·毕业设计·数据可视化
Highcharts.js34 分钟前
如何使用Highcharts SVG渲染器?
开发语言·javascript·python·svg·highcharts·渲染器
啊阿狸不会拉杆39 分钟前
《机器学习导论》第 7 章-聚类
数据结构·人工智能·python·算法·机器学习·数据挖掘·聚类