• VTK 图像基本操作_图像信息的访问与修改(vtkImageData)


    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)。

  • 相关阅读:
    oracle unwrap解密工具
    介绍一款国产的矢量图形设计软件--百绘大师
    windows10上安装OpenSSL_1.1.1d_x64
    centos7上安装phantomjs并对页面截屏
    如何用Java Socket实现一个简单的Redis客户端
    cenos上通过yum安装mariadb
    windows上杀掉指定名称的进程
    centos磁盘满时查找大文件清理掉
    为Vertica数据库增加自定义函数to_base64和from_base64
    解决Vertica集群某节点出现Clock skewed告警
  • 原文地址:https://www.cnblogs.com/ybqjymy/p/14241185.html
Copyright © 2020-2023  润新知