📄 itkgdcmimageiotest2.cxx
字号:
/*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: $RCSfile: itkGDCMImageIOTest2.cxx,v $
Language: C++
Date: $Date: 2007-08-20 12:21:34 $
Version: $Revision: 1.2 $
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#include "itkGDCMImageIO.h"
#include "itkImageFileReader.h"
#include "itkImageFileWriter.h"
#include "itkMetaDataObject.h"
#include "itkImageSeriesReader.h"
#include "itkImageSeriesWriter.h"
#include "itkNumericSeriesFileNames.h"
// Take as input any kind of image (typically RAW) and will create a valid
// DICOM MR image out of the raw image.
int main(int argc, char *argv[] )
{
if( argc < 3 )
{
std::cerr << "Usage: " << argv[0] << " InputFile OutputDicomRoot\n";
return EXIT_FAILURE;
}
const char *input = argv[1];
const char *output = argv[2];
typedef itk::Image<unsigned char,3> ImageType;
typedef itk::ImageFileReader<ImageType> ReaderType;
typedef itk::ImageFileWriter<ImageType> WriterType;
ReaderType::Pointer reader = ReaderType::New();
reader->SetFileName(input);
try
{
reader->Update();
}
catch (itk::ExceptionObject & e)
{
std::cerr << "exception in file writer " << std::endl;
std::cerr << e.GetDescription() << std::endl;
std::cerr << e.GetLocation() << std::endl;
return EXIT_FAILURE;
}
itk::GDCMImageIO::Pointer dicomIO = itk::GDCMImageIO::New();
//reader->GetOutput()->Print(std::cout);
itk::MetaDataDictionary & dict = dicomIO->GetMetaDataDictionary();
std::string tagkey, value;
tagkey = "0002|0002";
value = "1.2.840.10008.5.1.4.1.1.4"; // Media Storage SOP Class UID
itk::EncapsulateMetaData<std::string>(dict, tagkey, value );
tagkey = "0008|0060"; // Modality
value = "MR";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value );
tagkey = "0008|0008"; // Image Type
value = "DERIVED\\SECONDARY";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0008|0064"; // Conversion Type
value = "DV";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|5100"; // Patient Position
value = "HFS";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0020|1040"; // Position Reference Indicator
value = "";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0020"; // Scanning Sequence
value = "GR";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0021"; // Sequence Variant
value = "SS\\SP";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0022"; // Scan Options
value = "";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0023"; // MRA Acquisition Type
value = "";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0080"; // Repetition Time
value = "";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0081"; // Echo Time
value = "";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0091"; // Echo Train Length
value = "";
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
tagkey = "0018|0050"; // Slice Thickness
itksys_ios::ostringstream os;
os << reader->GetImageIO()->GetSpacing(2);
value = os.str();
itk::EncapsulateMetaData<std::string>(dict, tagkey, value);
// Construct different filename based on the root given
std::string output_j2k = output;
output_j2k += "-j2k.dcm";
std::string output_jpll = output;
output_jpll += "-jpll.dcm";
std::string output_raw = output;
output_raw += "-raw.dcm";
WriterType::Pointer writer = WriterType::New();
writer->SetImageIO(dicomIO);
writer->SetInput(reader->GetOutput());
writer->UseInputMetaDataDictionaryOff();
// Save as JPEG 2000 Lossless
// Explicitely specify which compression type to use
dicomIO->SetCompressionType(itk::GDCMImageIO::JPEG2000);
// Request compression of the ImageIO
writer->UseCompressionOn();
writer->SetFileName(output_j2k.c_str());
try
{
writer->Update();
}
catch (itk::ExceptionObject & e)
{
std::cerr << "exception in file writer " << std::endl;
std::cerr << e.GetDescription() << std::endl;
std::cerr << e.GetLocation() << std::endl;
return EXIT_FAILURE;
}
// Save as JPEG Lossless
dicomIO->SetCompressionType(itk::GDCMImageIO::JPEG);
writer->SetFileName(output_jpll.c_str());
try
{
writer->Update();
}
catch (itk::ExceptionObject & e)
{
std::cerr << "exception in file writer " << std::endl;
std::cerr << e.GetDescription() << std::endl;
std::cerr << e.GetLocation() << std::endl;
return EXIT_FAILURE;
}
// Save as raw
writer->UseCompressionOff();
writer->SetFileName(output_raw.c_str());
try
{
writer->Update();
}
catch (itk::ExceptionObject & e)
{
std::cerr << "exception in file writer " << std::endl;
std::cerr << e.GetDescription() << std::endl;
std::cerr << e.GetLocation() << std::endl;
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -