即日起在codingBlog上分享您的技术经验即可获得积分,积分可兑换现金哦。

ITK图像读写及显示

编程语言 webzhuce 32℃ 0评论
本文目录
[隐藏]

1.ITK图像读写机制

  1. 用户层面:itkImageFileReader(读) itkImageFileWriter(写)
  2. 内部实现:由内部ImageIO对象具体负责图像文件读写操作,该对象通过对象工厂根据用户输入文件类型生成相应的ImageIO对象

1.1.优点

  • 使用方便,用户无须关注内部实现细节
  • 扩展方便,扩展支持新的图像读取而无须修改用户接口,只需添加相应的工厂类和IO类

1.2.ITK图像读写类图:

这里写图片描述


以上内容摘自:


http://blog.csdn.net/ljp1919/article/details/41487505

2.示例说明

本示例演示itkImageFileReader和itkImageFileWriter的使用,并将ITK和VTK混合编程显示ITK读取的图像。

2.1.CMakeLists.txt文件代码如下:

CMAKE_MINIMUM_REQUIRED(VERSION 2.8)
PROJECT(ITKImageExample)
FIND_PACKAGE(ITK REQUIRED)
INCLUDE(${ITK_USE_FILE})
FIND_PACKAGE(VTK REQUIRED)
INCLUDE(${VTK_USE_FILE})
ADD_EXECUTABLE(ITKImageExample ITKImageExample.cpp)
TARGET_LINK_LIBRARIES(ITKImageExample ${ITK_LIBRARIES} ${VTK_LIBRARIES})

2.2.ITKImageExample.cpp文件代码如下:

#include "itkImage.h"
#include "itkImageFileReader.h"
#include "itkImageToVTKImageFilter.h"
#include "vtkImageViewer.h"
#include "vtkRenderWindowInteractor.h"

int main(int argc, char **argv)
{
    typedef itk::Image<unsigned short, 2> ImageType;
    typedef itk::ImageFileReader<ImageType> ReaderType;   //图像读取类
    typedef itk::ImageToVTKImageFilter<ImageType> ConnectorType;  //VTK和ITK链接器

    ReaderType::Pointer reader = ReaderType::New();
    ConnectorType::Pointer connector = ConnectorType::New();
    reader->SetFileName("E:\\TestData\\lenna.jpg");
    connector->SetInput(reader->GetOutput());
    connector->Update();

    vtkImageViewer *viewer = vtkImageViewer::New();
    vtkRenderWindowInteractor *interactor = vtkRenderWindowInteractor::New();
    viewer->SetInputData(connector->GetOutput());
    viewer->SetupInteractor(interactor);
    viewer->SetColorWindow(255); //设置窗宽
    viewer->SetColorLevel(128);   //设置窗位
    viewer->Render();
    interactor->Initialize();
    interactor->Start();
    return EXIT_SUCCESS;
}

2.3.运行结果:

这里写图片描述

转载请注明:CodingBlog » ITK图像读写及显示

喜欢 (0)or分享 (0)
发表我的评论
取消评论

*

表情