1.类vtkImageChengeInformation用于图像信息修改

vtkImageData中提供了多个Set函数用于设置图像的基本信息。当对一个管线的输出修改图像信息后,如果管线重新Update,那么这些修改都会恢复回原来的值。而vtkChangeImageInformation可以作为管线中的一个filter来修改图像信息。利用这个filter可以修改图像的原点,像素间隔以及范围起点(extent),另外还可以对图像平移缩放等操作。

2.代码及仿真

#include <vtkAutoInit.h>
VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h>
#include <vtkBMPReader.h>
#include <vtkImageData.h>
#include <vtkImageChangeInformation.h>
#include <vtkImageViewer2.h>
#include <vtkRenderer.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>int main()
{vtkSmartPointer<vtkBMPReader> reader =vtkSmartPointer<vtkBMPReader>::New();reader->SetFileName("lena.bmp");reader->Update();int dims[3];double origin[3];double spacing[3];reader->GetOutput()->GetDimensions(dims);std::cout << "图像维度:" << dims[0] << " " << dims[1] << " " << dims[2] << std::endl;reader->GetOutput()->GetOrigin(origin);std::cout << "图像中心:" << origin[0] << " " << origin[1] << " " << origin[2] << std::endl;reader->GetOutput()->GetSpacing(spacing);std::cout << "图像间隔:" << spacing[0] << " " << spacing[1] << " " << spacing[2] << std::endl;vtkSmartPointer<vtkImageChangeInformation> changer =vtkSmartPointer<vtkImageChangeInformation>::New();changer->SetInputData(reader->GetOutput());changer->SetOutputOrigin(100, 100, 0);changer->SetOutputSpacing(10, 10, 1);changer->SetCenterImage(1);changer->Update();changer->GetOutput()->GetDimensions(dims);std::cout << "图像维度:" << dims[0] << " " << dims[1] << " " << dims[2] << std::endl;changer->GetOutput()->GetOrigin(origin);std::cout << "图像中心:" << origin[0] << " " << origin[1] << " " << origin[2] << std::endl;changer->GetOutput()->GetSpacing(spacing);std::cout << "图像间隔:" << spacing[0] << " " << spacing[1] << " " << spacing[2] << std::endl;vtkSmartPointer<vtkImageViewer2> imgViewer =vtkSmartPointer<vtkImageViewer2>::New();imgViewer->SetInputConnection(changer->GetOutputPort());vtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();imgViewer->SetupInteractor(rwi);imgViewer->Render();imgViewer->GetRenderer()->ResetCamera();imgViewer->GetRenderer()->SetBackground(1.0, 1.0, 1.0);imgViewer->Render();imgViewer->GetRenderWindow()->SetWindowName("ChangeImageInfo");imgViewer->SetSize(640, 480);rwi->Start();return 0;
}

输出结果:

首先读入图像,由vtkImageData提供函数接口获取图像的维数,原点和像素间隔。然后定义vtkImageChangeInformation指针,并设置输出图像原点为(100, 100, 0),输出图像像素间隔为(10, 10, 1),然后调用CenterImage()函数将图像的原点置于图像的中心。

操作后的结果使得图像的原点位于(-2555, -2555, 0),SetOutputOrigin(100, 100, 0)并没有起作用。

原因在哪里呢?

如果看下CenterImage()函数的注释,可以发现该函数的作用是将(0, 0, 0)点置于图像的中心。当CenterImage该函数执行时会重写SetOutputOrigin(),所以SetOutputOrigin函数不会产生任何作用。那(-2555, -2555, 0)又是如何计算出来的呢?

这个原理如下图所示:

根据图像的维数和像素间隔计算得到新的图像的宽度和高度为(512-1)*10,初始图像的原点位于(0, 0,0),现在将图像的中心平移至原点,平移量为(-(512-1)*10/2,(512-1)*5/2, 0) = (-2555, -2555,0)。

VTK修炼之道18:图像基本操作_图像信息的访问与修改(vtkImageChangeInformation)相关推荐

  1. VTK修炼之道17:图像基本操作_图像信息的访问与修改(vtkImageData)

    1.利用vtkImageData实现图像信息的访问与修改 vtkImageData中提供了多个函数用于访问或者获取图像的基本信息,这些函数通常使用Set或者Get加上相应的信息名的形式,例如获取图像维 ...

  2. VTK修炼之道14:图像处理_创建

    1.引言:图像数据结构 数字图像文件内容由两个部分组成:图像头信息和数据.图像头信息定义了图像的基本信息,主要包括起点位置(Origin),像素间隔(space)和维数(dimension).通过这三 ...

  3. VTK修炼之道32:边缘检测_梯度算子

    1.梯度算子提取图像边缘 图像中不连续的灰度值会产生边缘,图像的边缘检测是基于边界的图像分割方法,如分水岭算法,通常是分割原图的梯度图像,梯度实际上也是反应的图像边缘信息.图像边缘一般常用图像一阶导数 ...

  4. VTK修炼之道16:图像处理_窗口分割和图像融合(ViewportvtkImageBlend)

    1.前言 前面演示的例子都是在一个窗口中显示一个图像.但是在常见的图像处理软件中,经常会遇到在一个窗口中显示多个图像,这就会用到图像融合技术.图像融合利用图像的alpha通道和不透明度来实现.VTK中 ...

  5. VTK修炼之道62:体绘制_固定点光线投影体绘制与GPU加速光线投影体绘制

    1.固定点光线投影算法 vtkFixedPointVolumeRayCastMapper是一个较好的vtkVolumeRayCastMapper的替代者.该类能够实现基于Alpha合成的体绘制方法和最 ...

  6. VTK修炼之道61:体绘制_光线投影+最大密度投影+等值面法

    1.vtkVolumeMapper vtkVolumeMapper是所有体绘制Mapper类的虚基类,提供接口函数,并由其子类实现具体功能.该类的继承关系如下图所示: 应该掌握一些常用的体绘制类. 2 ...

  7. VTK修炼之道60:体绘制_体绘制管线图形渲染管线

    1.几何渲染与体绘制 1.1 几何渲染 前面练习的渲染技术都是几何渲染技术.所谓的几何渲染技术,就是通过绘制几何图元(顶点.线段.面片等)来渲染数据,例如:绘制图像需要在空间中建立一个四边形图元,然后 ...

  8. VTK修炼之道39:图像平滑_各向异性滤波

    1.各向异性扩散滤波 高斯平滑方法在平滑噪声的同时,模糊了图像的重要边缘图像. 各向异性滤波是一种基于偏微分方程的滤波技术,建立于热量的各向异性扩散理论. 各向异性滤波在图像的平坦区域选择大尺度平滑, ...

  9. VTK修炼之道38:图像平滑_中值滤波器

    1.中值滤波 vtkImageHybridMedian2D实现了对二维图像的中值滤波.其实现原理是,采用一个5x5的模板,逐次将模板中心对应于图像的每个像素上,将模板图像覆盖的像素的中值作为当前像素的 ...

最新文章

  1. 不信你看!这次Python和AI真的玩儿大了!!
  2. 在spring MVC项目中集成Spring session redis (使用spring session框架,redis作为存储缓存)...
  3. POPUP_TO_CONFIRM_WITH_VALUE
  4. TCP/IP协议族 详解(TCP/IP四层模型、OSI七层模型)
  5. Linux中磁盘分区的管理
  6. vue+node全栈移动商城【6】-node接口配置文件
  7. 因供应商遭不明网络攻击,丰田汽车宣布停产
  8. list删除数据的唯一正确写法
  9. 去掉matlab图片空白边缘
  10. Linux下Libtorch运行出现free(): invalid pointer报错
  11. matlab中输出汉字的函数,matlab中的输出显示函数
  12. 改行当和尚 难于上青天
  13. BGP路由技术详解(一)
  14. 信息安全意识教育日历——By 安全牛
  15. Only no-arg methods may be annotated with @Scheduled 的解决方法
  16. superset集成echarts--添加Line折线图
  17. php获取拼音首字母排序,php 如何获取字符串拼音首字母 - strtoupper
  18. 菜鸟学数据库——大话 char、varchar、 nchar、nvarchar之间剪不断理还乱的关系
  19. goland试用期过后继续使用方式
  20. Unity游戏开发视频教程 第2卷

热门文章

  1. HTML与XHTML差额
  2. javascript12-object04-毕包
  3. USACO crypt1
  4. poj 1230(贪心)
  5. bnuoj 20950 沉重的货物 (最小生成树)
  6. 并发编程知识点一张图总结
  7. python模块、字符编码、文件读写
  8. 强/若类型语言 动/静态语言
  9. Windows系统下使用Sublime搭建nodejs环境
  10. xcode7,AFN不能使用的问题