使用 VTK 也可以实现等高线绘制,在地图、气象、地质等领域中,经常需要将数据以多个等高线的形式进行展示。在VTK(Visualization Tookt) 中,有专门的AP何以支持简便地实现这一功能。
我们还可以根据算法操作的数据类型或生成的数据类型对算法进行分类。通过类型,我们通常是指属性数据的类型,例如标量或向量。
•标量算法对标量数据进行操作。例如,在天气图上生成温度等高线。
•向量算法对向量数据进行运算。显示气流方向箭头(方向和大小)是矢量可视化的一个例子。
对颜色映射的自然延伸是轮廓。当我们看到用数据值着色的表面时,眼睛通常会将类似颜色的区域分割成不同的区域。当我们等高线数据时,
我们有效地构建了这些区域之间的边界。这些边界对应于常数标量值的等高线(2D)或曲面(3D)。
import vtk
def main():
# import data
reader = vtk.vtkPolyDataReader()
#reader = vtk.vtkDataSetReader()
#reader.SetFileName('G:/myproject/2023/03/OCT_2d-3d/1.vtk')
reader.ReadAllVectorsOn()
reader.ReadAllScalarsOn()
reader.Update()
# create the filter
contours = vtk.vtkContourFilter()
contours.SetInputData(reader.GetOutput())
contours.GenerateValues(5, 0., 5.)
contours.Update()
# create the mapper
mapper = vtk.vtkPolyDataMapper()
mapper.SetInputData(contours.GetOutput())
mapper.ScalarVisibilityOff()
mapper.SetScalarRange(0., 5.)
# create the actor
actor = vtk.vtkActor()
actor.SetMapper(mapper)
# create a rendering window and renderer
ren = vtk.vtkRenderer()
ren.SetBackground(0.329412, 0.34902, 0.427451) # Paraview blue
# Assign actor to the renderer
ren.AddActor(actor)
renWin = vtk.vtkRenderWindow()
renWin.AddRenderer(ren)
renWin.SetSize(750, 750)
# create a renderwindowinteractor
iren = vtk.vtkRenderWindowInteractor()
iren.SetRenderWindow(renWin)
ren.ResetCamera()
# render
renWin.Render()
# screenshot
w2if = vtk.vtkWindowToImageFilter()
w2if.SetInput(renWin)
w2if.Update()
#w2if.SetMagnification(5.)
writer = vtk.vtkPNGWriter()
writer.SetFileName("screenshot.png")
writer.SetInputData(w2if.GetOutput())
writer.Write()
# Enable user interface interactor
iren.Initialize()
iren.Start()
main()