- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一组数据存储在一个 VTK 文件中,它表示通过一个数组中标量点数据的域的切割。我正在尝试生成所述标量的等高线图,使其看起来有点像使用 ParaView 制作的附加图片。我宁愿坚持使用 vtk 库,也不愿使用其他东西,比如 Matplotlib,因为我认为它们通常会产生更好的可视化效果。 .
我在网上看了几个例子,但没有一个对我有用(没有抛出错误,我最终得到的只是一个只有背景的空渲染),我所能做的只是一个表面数据图(例如:here)。
这是我当前版本的代码(与成功生成曲面图的代码非常相似):
# import data
reader = vtk.vtkDataSetReader()
reader.SetFileName('inputDataFiles/k_zCut.vtk')
reader.ReadAllVectorsOn()
reader.ReadAllScalarsOn()
reader.Update()
# access data
data = reader.GetOutput()
d = data.GetPointData()
array=d.GetArray('k')
# create the filter
contours = vtk.vtkContourFilter()
contours.SetInput(reader.GetOutput())
contours.GenerateValues(5,1.,5.)
# create the mapper
mapper = vtk.vtkPolyDataMapper()
mapper.SetInput(contours.GetOutput())
mapper.ScalarVisibilityOff()
mapper.SetScalarRange(1., 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)
# render
renWin.Render()
# screenshot
w2if = vtk.vtkWindowToImageFilter()
w2if.SetInput(renWin)
w2if.Update()
w2if.SetMagnification(5.)
writer = vtk.vtkPNGWriter()
writer.SetFileName("screenshot.png")
writer.SetInput(w2if.GetOutput())
writer.Write()
# Enable user interface interactor
iren.Initialize()
iren.Start()
下面您可以看到我的输入文件的缩短部分。任何帮助将不胜感激。
# vtk DataFile Version 2.0
sampleSurface
ASCII
DATASET POLYDATA
POINTS 34813 float
0 0 0
0 -0.000191589 0
0.000264399 0.000157061 0
0 0.000313389 0
0.000264347 -0.000191923 0
0 -0.000383178 0
-0.000395709 0 0
-0.000395709 0.000156695 0
3.60174e-05 0.000486922 0
0.000528387 0 0
POLYGONS 69284 277136
3 4105 4371 3861
3 4102 3861 4371
3 4656 4371 4373
3 4105 4373 4371
3 3624 3861 3390
3 3621 3390 3861
3 4105 3863 3861
3 3624 3861 3863
3 3188 3390 2990
3 3187 2990 3390
3 3624 3390 3391
3 3188 3391 3390
POINT_DATA 34813
FIELD attributes 1
k 1 34813 float
0.849464 0.391519 1.52947 1.05206 0.391519 0.253736 1.39481 1.39481 0.636517 1.21019
0.640193 0.114295 1.12557 0.644143 0.629569 0.114295 0.485032 0.477396 1.39961 0.0860201
1.66665 1.24058 1.45939 0.483719 1.01318 0.163198 0.317574 0.792821 0.317125 0.658835
最佳答案
如果您想对 VTK 使用更“pythonic”的界面,consider using mayavi
/tvtk
/mlab
. (无论哪种方式,VTK 都是一个很好的选择!)
tvtk
是一个稍微更 pythonic 的、低级别的 python 绑定(bind)到 VTK,具有一些非常好的特性(例如 numpy 数组的透明使用)。
Mayavi 和 mlab 为 VTK 提供了更高级的接口(interface)。
您显示的数据文件片段按原样无效,但如果我们使用类似的片段:
# vtk DataFile Version 2.0
Simple VTK file example
ASCII
DATASET POLYDATA
POINTS 9 float
3.0 0.0 0.0
1.0 1.0 0.0
0.0 3.0 0.0
3.0 0.0 1.0
1.0 1.0 1.0
0.0 3.0 1.0
3.0 2.0 2.0
2.0 2.0 2.0
2.0 3.0 2.0
TRIANGLE_STRIPS 2 14
6 0 3 1 4 2 5
6 3 6 4 7 5 8
POINT_DATA 9
SCALARS nodal float
LOOKUP_TABLE default
0.0 0.1 0.0 0.3 0.6 0.3 0.8 1.0 0.8
在表面上渲染轮廓可以很简单:
from mayavi import mlab
source = mlab.pipeline.open('test.vtk')
lines = mlab.pipeline.contour_surface(source)
mlab.show()
或者我们可以变得更奇特一点:
from mayavi import mlab
# Make a figure with a black background
fig = mlab.figure(bgcolor=(0,0,0))
# Also see methods like: fig.scene.z_plus_view(), etc
fig.scene.camera.azimuth(215)
source = mlab.pipeline.open('test.vtk')
# Show the surface, colored by the scalars
surf = mlab.pipeline.surface(source)
# Draw contours of the scalars on the surface
lines = mlab.pipeline.contour_surface(source)
mlab.show()
关于python - 使用 Python 从 vtk 文件中的数据绘制等高线图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21500190/
当我使用 vtkPolyDataWriter 创建 vtk 遗留文件时,我获得了具有连接性和偏移量的新版本数据文件 (5.1)。是否可以更改它并获得“遗留”旧格式? gmsh 似乎无法读取新格式版本的
我有一个不规则数据,x 维 - 384,y 维 - 256 和 z 维 64。现在这些坐标存储在 3 个单独的二进制文件中,我有一个数据文件,其中包含这些点的数据值。我想知道,我如何表示这样的数据以便
所以我有一个点,并在 z 轴上创建一条线以查看与某个网格的交点(将网格上的点投影到 z 轴上)。 所以我创建了一个 vtkCellLocator,但是函数的每个参数是什么?文档中根本没有描述它: in
我想将旧版 .vtk 文件转换为二进制文件,最好是 .vtu 文件,因为我使用的是非结构化网格。为此,我改编了来自 http://www.vtk.org/Wiki/VTK/Examples/Cxx/I
我想在 paraview 中可视化一些图形:一堆带有坐标的点,它们之间有一堆边。我还想给点和边线上色。我认为这对 vtk 格式来说并不难,因为我发现 vtk 格式示例几乎有我需要的东西。 据我所知,p
我想将旧版 .vtk 文件转换为二进制文件,最好是 .vtu 文件,因为我使用的是非结构化网格。为此,我改编了来自 http://www.vtk.org/Wiki/VTK/Examples/Cxx/I
我有与 VTK 集成的 Visual Studio MFC 项目。单击我的项目上的按钮将生成一个 VTK 窗口,当我第二次单击同一按钮并打开一个新的 VTK 窗口时,我想关闭该 VTK 窗口。 我当前
当我尝试在 ParaView 中加载大小约为 100mb 的 VTK 文件时,程序崩溃了。但是,如果我通过选择更少的数据点(现在平均大小约为 30mb)来减小文件的大小,它会毫无问题地加载。 我不确定
我在 3D numpy.ndarray 中有一个分段,我想将其渲染到 VTK 中。 [参见这里类似的过程:https://pyscience.wordpress.com/2014/11/16/volu
我已遵循介绍指南:https://kitware.github.io/vtk-js/docs/develop_requirement.html安装 vtk、node 和 git。 我一直在尝试集成到
在我的计算过程中,我保存了一堆与单个时间步长相关的 .vtk 文件。每个文件都使用 POLYDATA ASCII 文件格式描述一个多面体(我定义的一个 C++ 类)。多面体由多面体类的一个简单成员函数
目前,我们正在使用 Python 的 vtk 包装器和 Pyvista(一个更 pythonist 的 vtk 包装器)。 在过程的某些部分,我们有一些来自 .cxx 文件的日志行: 2022-03-
当我使用 mayavi (4.3.1) 可视化网格时,它会提示以下警告: 警告:导入的 VTK 版本 (5.1) 与使用的版本不匹配 构建 TVTK 类 (6.3)。这可能会导致问题。 请重建TVTK
我正在尝试将计算标量添加到现有 VTK 文件中。 我的代码的简化版本如下 import vtk import os import numpy as np reader = vtk.vtkDataSet
对于当前的项目,我必须使用矩阵中提供的信息并对其进行数学计算,以及使用 ITK/VTK 函数来显示医疗信息/渲染。基本上我必须以(我猜)50/50 的方式同时使用 matlab 例程和 VTK/ITK
我有一条小 python VTK计算嵌入在 TIFF 图像堆栈中的对象的体积和表面积的函数。为了将 TIFF 的 读入 VTK,我使用了 vtkTIFFReader 并使用 vtkImageThres
目前,我正在尝试结合使用 VTK 库和 Qt 来构建一个可视化 STL 文件的应用程序。为了开始,我安装了以下库/程序: Visual Studio 2015 专业版 CMake 3.7.0 VTK
如何获取数据集的范围?也称为数据的边界框。使用 StructuredPointsReader 读取数据. 最佳答案 因为 vtkStructuredPoints(vtkStructuredPoints
我正在尝试使用分析字段填充结构化网格,但是尽管阅读了vtk文档,但我还没有找到如何在网格点上实际设置标量值或设置网格的间距/原点信息的方法。从下面的代码开始,我该如何 将空间信息与网格相关联(即,单元
CGAL和VTK库之间有什么区别?两者都包含许多标准几何算法。谁能列出一些优先于另一个的应用程序域? 最佳答案 VTK主要针对可视化(前端)。它不方便地包含一些计算几何函数(例如Delaunay三角剖
我是一名优秀的程序员,十分优秀!