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

  • 相关阅读:
    省市区三级联动
    jeDate日期控件
    Juery返回Json数据格式,webForm中使用
    JS补充
    winfrom中上传文件保存在webFrom里面
    游标
    函数
    触发器
    Leetcode练习(Python):数组类:第106题:根据一棵树的中序遍历与后序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。
    Leetcode练习(Python):数组类:第105题:根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。
  • 原文地址:https://www.cnblogs.com/ybqjymy/p/14241185.html
Copyright © 2020-2023  润新知