《itk实用demo》-itk读取mha写vtk

itk读取mha写vtk


#include "itkImage.h"
#include "itkDICOMImageIO2.h"
#include "itkImageFileReader.h"
#include "itkImageFileWriter.h"

using namespace std;

typedef short PixelType;
typedef itk::Image<PixelType,3> ImageType;

int main( int argc, char* argv[] )
{
 cout<<"-------------Read----------"<<endl;
 //itk::DICOMImageIO2::Pointer dicomIO = itk::DICOMImageIO2::New();
 //itk::DICOMSeriesFileNames::Pointer nameGenerator = itk::DICOMSeriesFileNames::New();
 //nameGenerator->SetDirectory("D:\\MedImg\\old\\SE0");
 nameGenerator->SetDirectory("D:\\MedImg\\111\\0603030007\\ST0\\SE0");
 //typedef std::vector<std::string> fileNamesContainer;
 //fileNamesContainer fileNames;
 //fileNames = nameGenerator->GetFileNames();
 //typedef itk::ImageSeriesReader<ImageType>    ReaderType;
 //ReaderType::Pointer pReader = ReaderType::New();
 //pReader->SetFileNames( fileNames );
 //pReader->SetImageIO( dicomIO );
 //try
 //{
 // pReader->Update();
 //}
 //catch (itk::ExceptionObject &ex)
 //{
 // std::cout << ex << std::endl;  
 // return 0;
 //}

 typedef itk::ImageFileReader< ImageType >  ReaderType;
 ReaderType::Pointer pReader = ReaderType::New();
 const char * inputFilename  = "D:\\1.mha";
 pReader->SetFileName( inputFilename  );
 try
 {
  pReader->Update();
 }
 catch (itk::ExceptionObject &ex)
 {
  std::cout << ex << std::endl;  
  return 0;
 }
 //----- 灰度图像----------------------------------------------------------------
 typedef itk::ImageFileWriter< ImageType > WriterType;
 WriterType::Pointer writer_heart = WriterType::New();
 std::cout  << "Writing the image as " << std::endl << std::endl;
 std::cout  << "D:\\se6\\ct4\\0.vtk"  << std::endl << std::endl;
 writer_heart->SetFileName( "D:\\1.vtk" );
 writer_heart->SetInput( pReader->GetOutput() );
 try
 {
  writer_heart->Update();
 }
 catch (itk::ExceptionObject &ex)
 {
  std::cout << ex;
  return EXIT_FAILURE;
 }
 return EXIT_SUCCESS;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值