VTK-Python 5. 为数据添加过滤器

#!/usr/bin/env python

import vtk


def main():
    # create data manually
    # cylinder = vtk.vtkCylinderSource()
    # cylinder.SetHeight(3.0) # 设置柱体的高
    # cylinder.SetRadius(1.0) #  设置柱体横截面的半径
    # cylinder.SetResolution(6) # 设置柱体横截面的等边多边形的边数

    # Read from file
    stlreader = vtk.vtkSTLReader()
    stlreader.SetFileName("42400-IDGH.stl")

    # add a filter
    # 创建过滤器对象,该对象将输入数据集的每个单元向单元质心收缩将会导致相邻单元之间出现裂缝
    shrink = vtk.vtkShrinkPolyData()
    shrink.SetInputConnection(stlreader.GetOutputPort())
    shrink.SetShrinkFactor(0.9)

    cylinderMapper = vtk.vtkPolyDataMapper() # 渲染多边形几何数据
    cylinderMapper.SetInputConnection(shrink.GetOutputPort()) # VTK可视化管线的输入数据接口 ,对应的可视化管线输出数据的接口为GetOutputPort();
    cylinderActor = vtk.vtkActor()
    cylinderActor.SetMapper(cylinderMapper) # 设置生成几何图元的Mapper。即连接一个Actor到可视化管线的末端(可视化管线的末端就是Mapper)。
    renderer = vtk.vtkRenderer() # 负责管理场景的渲染过程
    renderer.AddActor(cylinderActor)
    renderer.SetBackground(0.1, 0.2, 0.4)
    renWin = vtk.vtkRenderWindow() # 将操作系统与VTK渲染引擎连接到一起。
    renWin.AddRenderer(renderer)
    renWin.SetSize(300, 300)
    iren = vtk.vtkRenderWindowInteractor() # 提供平台独立的响应鼠标、键盘和时钟事件的交互机制
    iren.SetRenderWindow(renWin)

    # 交互器样式的一种,该样式下,用户是通过控制相机对物体作旋转、放大、缩小等操作
    style = vtk.vtkInteractorStyleTrackballCamera()

    iren.SetInteractorStyle(style)
    iren.Initialize()

    iren.Start()

    # Clean up
    # del cylinder
    del stlreader
    del shrink
    del cylinderMapper
    del cylinderActor
    del renderer
    del renWin
    del iren

main()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Python显示VTK中点的属性值,可以使用以下步骤: 1. 读取点云数据并创建点云对象: ```python import vtk # 读取点云数据 reader = vtk.vtkPLYReader() reader.SetFileName("pointcloud.ply") reader.Update() # 创建点云对象 point_cloud = vtk.vtkPointCloud() point_cloud.SetInputConnection(reader.GetOutputPort()) ``` 2. 创建点云的属性过滤器,并设置需要显示的属性: ```python # 创建属性过滤器 property_filter = vtk.vtkVertexGlyphFilter() property_filter.SetInputConnection(reader.GetOutputPort()) property_filter.Update() # 设置需要显示的属性 property_name = "intensity" property_array = reader.GetOutput().GetPointData().GetArray(property_name) point_cloud.GetMapper().SetScalarRange(property_array.GetRange()) point_cloud.GetMapper().SetScalarModeToUsePointFieldData() point_cloud.GetMapper().SelectColorArray(property_name) ``` 3. 创建点云的渲染器并添加点云对象: ```python # 创建渲染器 renderer = vtk.vtkRenderer() renderer.SetBackground(1, 1, 1) # 添加点云对象 renderer.AddActor(point_cloud) # 创建窗口 window = vtk.vtkRenderWindow() window.AddRenderer(renderer) window.SetSize(800, 600) # 显示窗口 interactor = vtk.vtkRenderWindowInteractor() interactor.SetRenderWindow(window) interactor.Initialize() window.Render() interactor.Start() ``` 运行以上代码后,将会显示一个带有点云属性值的窗口。可以在代码中修改 `property_name` 变量的值以显示不同的属性值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值