一連の 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;
}