1 /*=========================================================================
4 Module: $RCSfile: bbitkImageSeriesReader.cxx,v $
6 Date: $Date: 2008/05/16 14:03:19 $
7 Version: $Revision: 1.4 $
9 Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
10 l'Image). All rights reserved. See Doc/License.txt or
11 http://www.creatis.insa-lyon.fr/Public/bbtk/License.html for details.
13 This software is distributed WITHOUT ANY WARRANTY; without even
14 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 PURPOSE. See the above copyright notices for more information.
17 =========================================================================*/
24 #include "bbitkImageSeriesReader.h"
25 #include "bbitkPackage.h"
26 #include "itkImageSeriesReader.h"
30 BBTK_BLACK_BOX_IMPLEMENTATION(ImageSeriesReader,bbtk::AtomicBlackBox);
32 BBTK_ADD_BLACK_BOX_TO_PACKAGE(itk,ImageSeriesReader);
37 void ImageSeriesReader::Read()
39 const std::vector<std::string>& filenames = bbGetInputFileNames();
40 if (!filenames.size())
42 typedef Image_uint8_t_2_ptr itype;
43 Image_uint8_t_2::Pointer p = Image_uint8_t_2::New();
44 Image_uint8_t_2::IndexType i;
46 Image_uint8_t_2::SizeType s;
48 Image_uint8_t_2::RegionType r(i,s);
52 bbSetOutputOut(p.GetPointer());
54 //bbtkError("Void vector passed to "<<bbGetFullName());
57 std::string filename = filenames[0];
59 itk::ImageIOBase::Pointer genericReader =
60 itk::ImageIOFactory::CreateImageIO(filename.c_str(),
61 itk::ImageIOFactory::ReadMode);
64 bbtkError(bbGetFullName()<<" : File format unknown (while reading \"" << filename << "\")");
66 genericReader->SetFileName(filename.c_str());
67 genericReader->ReadImageInformation();
69 bbtk::TypeInfo typ = GetITKImagePtrTypeInfoFromPixelTypeInfoAndDimension(genericReader->GetComponentTypeInfo(), genericReader->GetNumberOfDimensions());
71 BBTK_TEMPLATE_ITK_IMAGE_SWITCH(typ,Read);
81 void ImageSeriesReader::Read()
83 bbtkDebugMessageInc("Core",9,"bbitk::ImageSeriesReader<"
85 <<">::Read()"<<std::endl);
89 typedef T itkImageType;
90 typedef itk::ImageSeriesReader< itkImageType > itkReaderType;
92 typename itkReaderType::Pointer reader = itkReaderType::New();
93 const std::vector<std::string>& filenames = bbGetInputFileNames();
94 reader->SetFileNames(filenames);
95 try { reader->Update(); }
96 catch( std::exception& e )
98 bbtkError("could not read image series : "<<e.what());
101 reader->GetOutput()->Register();
102 // if (bbGetOutputOut())
103 bbSetOutputOut ( reader->GetOutput() );
105 bbtkDebugDecTab("Core",9);