我想阅读一系列 DICOM 图像以使用 ITK 将它们转换为 3D 图像。我遵循文档中的示例:“Examples/IO/DicomSeriesReadImageWrite2.cxx”。但是我仍然遇到问题,我解决了一些问题,但我想听听任何提示,拜托!
问题出在下划线的代码行,代码就在下面,而且没那么长。它编译,变量 'seriesItr' 的值 = "1.2.392.200036.9116.2.6.1.48.1214834239.1284941923.42443543.0512512" 。但是变量 'seriesEnd' 是一个空指针!我究竟做错了什么?感谢您在高级方面的帮助!
// Reading a 2D DICOM Series and Writing a Volume
ReaderType::Pointer reader = ReaderType::New();
ImageIOType::Pointer dicomIO = ImageIOType::New();
reader->SetImageIO( dicomIO );
NamesGeneratorType::Pointer nameGenerator = NamesGeneratorType::New();
nameGenerator->SetUseSeriesDetails( true );
std::string folder;
folder = "C:\\Documents and Settings\\GTTS\\Mis documentos\\Visual Studio 2008\\Projects\\Reg_mono3D\\Reg_mono3D\\DICOM_SERIES\\T\\";
nameGenerator->SetDirectory(folder);
const SeriesIdContainer & seriesUID = nameGenerator->GetSeriesUIDs();
SeriesIdContainer::const_iterator seriesItr = seriesUID.begin();
***SeriesIdContainer::const_iterator seriesEnd = seriesUID.end();***
while( seriesItr != seriesEnd )
{
std::cout << seriesItr->c_str() << std::endl;
seriesItr++;
}
std::string seriesIdentifier;
seriesIdentifier = seriesUID.begin()->c_str();
FileNamesContainer fileNames;
fileNames = nameGenerator->GetFileNames( seriesIdentifier );
reader->SetFileNames( fileNames );
try
{
reader->Update();
}
catch (itk::ExceptionObject &ex)
{
cout << ex << std::endl;
}