1.利用vtkImageData实现图像信息的访问与修改
vtkImageData中提供了多个函数用于访问或者获取图像的基本信息,这些函数通常使用Set或者Get加上相应的信息名的形式,例如获取图像维数的方法定义为GetDimensions()。
2.实验程序及运行结果
1 #include <vtkAutoInit.h>
2 VTK_MODULE_INIT(vtkRenderingOpenGL);
3
4 #include <vtkSmartPointer.h>
5 #include <vtkBMPReader.h>
6 #include <vtkImageData.h>
7 #include <vtkImageViewer2.h>
8 #include <vtkRenderer.h>
9 #include <vtkRenderWindow.h>
10 #include <vtkRenderWindowInteractor.h>
11
12 int main()
13 {
14 //读数据
15 vtkSmartPointer<vtkBMPReader> reader =
16 vtkSmartPointer<vtkBMPReader>::New();
17 reader->SetFileName("lena.bmp");
18 reader->Update();
19
20 //获取图像信息
21 int dims[3];
22 reader->GetOutput()->GetDimensions(dims);
23 std::cout << "图像维数:" << dims[0] << "*" << dims[1] << "*" << dims[2] << std::endl;
24
25 double origin[3];
26 reader->GetOutput()->GetOrigin(origin);
27 std::cout << "图像中心:" << origin[0] << " " << origin[1] << " " << origin[2] << std::endl;
28
29 double spacing[3];
30 reader->GetOutput()->GetSpacing(spacing);
31 std::cout << "图像间距:" << spacing[0] << " " << spacing[1] << " " << spacing[2] << std::endl;
32
33 //显示图像
34 vtkSmartPointer<vtkImageViewer2> imgViewer =
35 vtkSmartPointer<vtkImageViewer2>::New();
36 imgViewer->SetInputConnection(reader->GetOutputPort());
37
38 vtkSmartPointer<vtkRenderWindowInteractor> rwi =
39 vtkSmartPointer<vtkRenderWindowInteractor>::New();
40 imgViewer->SetupInteractor(rwi);
41 imgViewer->Render();
42
43 imgViewer->GetRenderer()->ResetCamera();
44 imgViewer->Render();
45
46 imgViewer->GetRenderer()->SetBackground(1.0, 1.0, 1.0);
47 imgViewer->SetSize(640,480);
48
49 imgViewer->GetRenderWindow()->SetWindowName("GetImageInfo");
50 rwi->Start();
51 return 0;
52 }
运行结果:
这个例子主要获取图像的三个信息:图像维数、图像原点、像素间隔。VTK中二维和三维图像都用vtkImageData表示,因此首先定义图像维数为dims[3],然后利用GetDimensions()函数获取图像的维数;图像的原点和像素间隔都是物理空间数值,因此都是定义double类型。其中,图像维数为512*512*1,通过维数可以看成z方向的维数为1,说明该图像为二维图像;而图像的原点为(0,0,0)点,而像素间隔为(1,1,1)。
分类:
VTK
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
2020-01-06 VisionPro 图标工具说明
2020-01-06 Qt OpenCV::Mat与Qt::QImage相互转换
2020-01-06 QT .和::和:和->
2020-01-06 Qt QImage的浅拷贝与深拷贝
2020-01-06 Qt QImag图像保存、格式转换
2020-01-06 Qt 获取当前时间
2020-01-06 Qt 信号阻塞和断开