Python VTK 给点添加颜色


目录

前言:

效果:

code:


 

前言:

  有时间我们需要给点加上颜色

效果:

 

code:

 
import vtk
from numpy import random
import os

class VtkPointCloud:

    def __init__(self, yMin=-10.0, yMax=10.0, maxNumPoints=1e6):
        self.maxNumPoints = maxNumPoints
        self.vtkPolyData = vtk.vtkPolyData()
        self.clearPoints()
        mapper = vtk.vtkPolyDataMapper()
        mapper.SetInputData(self.vtkPolyData)
        mapper.SetColorModeToDefault()
        mapper.SetScalarRange(yMin, yMax)
        mapper.SetScalarVisibility(1)
        self.vtkActor = vtk.vtkActor()
        self.vtkActor.GetProperty().SetPointSize(3)
        self.vtkActor.SetMapper(mapper)

    def addPoint(self, point):

        pointId = self.vtkPoints.InsertNextPoint(point[:])
        self.vtkDepth.InsertNextValue(point[1])
        self.vtkCells.InsertNextCell(1)
        self.vtkCells.InsertCellPoint(pointId)


    def clearPoints(self):
        self.vtkPoints = vtk.vtkPoints()
        self.vtkCells = vtk.vtkCellArray()
        self.vtkDepth = vtk.vtkDoubleArray()
        self.vtkDepth.SetName('DepthArray')
        self.vtkPolyData.SetPoints(self.vtkPoints)
        self.vtkPolyData.SetVerts(self.vtkCells)
        self.vtkPolyData.GetPointData().SetScalars(self.vtkDepth)
        self.vtkPolyData.GetPointData().SetActiveScalars('DepthArray')


reader = vtk.vtkSTLReader()
reader.SetFileName("lung.stl")
reader.Update()

bounds = reader.GetOutput().GetBounds()
pointCloud = VtkPointCloud(bounds[2], bounds[3])

total = reader.GetOutput().GetNumberOfPoints()
for number in range(total):
    point = reader.GetOutput().GetPoints().GetPoint(number)
    pointCloud.addPoint(point)

# Renderer
renderer = vtk.vtkRenderer()
renderer.AddActor(pointCloud.vtkActor)
renderer.SetBackground(.2, .3, .4)
renderer.ResetCamera()

# Render Window
renderWindow = vtk.vtkRenderWindow()
renderWindow.AddRenderer(renderer)

# Interactor
renderWindowInteractor = vtk.vtkRenderWindowInteractor()
renderWindowInteractor.SetRenderWindow(renderWindow)

# Begin Interaction
renderWindow.Render()
renderWindowInteractor.Start()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Python 中使用 VTK(Visualization Toolkit)显示图片,可以按照以下步骤进行操作: 1. 安装 VTK:打开终端或命令提示符,运行以下命令安装 VTK 库: ``` pip install vtk ``` 2. 导入所需模块:在 Python 脚本中导入必要的模块。 ```python import vtk ``` 3. 创建渲染器和交互窗口:创建一个渲染器和交互窗口,用于显示图像。 ```python renderer = vtk.vtkRenderer() renderWindow = vtk.vtkRenderWindow() renderWindow.AddRenderer(renderer) renderWindowInteractor = vtk.vtkRenderWindowInteractor() renderWindowInteractor.SetRenderWindow(renderWindow) ``` 4. 加载图像数据:使用 `vtkPNGReader` 或 `vtkJPEGReader` 等类来加载图像数据。 ```python reader = vtk.vtkPNGReader() reader.SetFileName("path/to/image.png") reader.Update() ``` 5. 创建图像数据源和演员:将加载的图像数据转换为 VTK 图像数据源,并创建对应的演员。 ```python imageSource = vtk.vtkImageActor() imageSource.SetInputData(reader.GetOutput()) ``` 6. 将演员添加到渲染器中:将图像数据的演员添加到渲染器中。 ```python renderer.AddActor(imageSource) ``` 7. 设置渲染器和交互窗口的属性:设置渲染器和交互窗口的一些属性,如背景颜色、交互样式等。 ```python renderer.SetBackground(1.0, 1.0, 1.0) # 设置背景为白色 renderWindow.SetSize(800, 600) # 设置窗口大小 style = vtk.vtkInteractorStyleImage() renderWindowInteractor.SetInteractorStyle(style) # 设置交互样式为图像样式 ``` 8. 开启交互窗口:启动交互窗口,显示图像。 ```python renderWindow.Render() renderWindowInteractor.Start() ``` 以上是使用 VTKPython 中显示图像的基本步骤,你可以根据需要进行进一步的定制和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

恋恋西风

up up up

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值