From 22ad7fa08e3dac717011143e08e10c8435c3c7c2 Mon Sep 17 00:00:00 2001 From: jean-pierre roux Date: Thu, 27 Nov 2008 14:55:54 +0000 Subject: [PATCH] We can pass the spacing,if the input image doesn't have (and if we now it) --- packages/itk/src/bbitkImageSeriesReader.cxx | 44 ++++++++++++++++++++- packages/itk/src/bbitkImageSeriesReader.h | 20 ++++++++-- 2 files changed, 59 insertions(+), 5 deletions(-) diff --git a/packages/itk/src/bbitkImageSeriesReader.cxx b/packages/itk/src/bbitkImageSeriesReader.cxx index 1a18bcb..68de42d 100644 --- a/packages/itk/src/bbitkImageSeriesReader.cxx +++ b/packages/itk/src/bbitkImageSeriesReader.cxx @@ -2,8 +2,8 @@ Program: bbtk Module: $RCSfile: bbitkImageSeriesReader.cxx,v $ Language: C++ - Date: $Date: 2008/11/26 10:13:32 $ - Version: $Revision: 1.7 $ + Date: $Date: 2008/11/27 14:55:54 $ + Version: $Revision: 1.8 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -44,6 +44,21 @@ namespace bbitk BBTK_ADD_BLACK_BOX_TO_PACKAGE(itk,ImageSeriesReader); + void ImageSeriesReader::bbUserConstructor() + { + bbSetInputXSpacing(-1.); + bbSetInputYSpacing(-1.); + bbSetInputZSpacing(-1.); + } + + void ImageSeriesReader::bbUserCopyConstructor(bbtk::BlackBox::Pointer) + { + } + + void ImageSeriesReader::bbUserDestructor() + { + } + void ImageSeriesReader::Read() { const std::vector& filenames = bbGetInputFileNames(); @@ -77,6 +92,7 @@ namespace bbitk genericReader->SetFileName(filename.c_str()); genericReader->ReadImageInformation(); + // a stack of 2D images will result as a 3D image // JPRx int plusUn; if (filenames.size()>1) plusUn = 1; @@ -84,6 +100,7 @@ namespace bbitk plusUn = 0; bbtk::TypeInfo typ = GetITKImagePtrTypeInfoFromPixelTypeInfoAndDimension(genericReader->GetComponentTypeInfo(), genericReader->GetNumberOfDimensions() + plusUn); + BBTK_TEMPLATE_ITK_IMAGE_SWITCH(typ,Read); @@ -111,6 +128,29 @@ namespace bbitk bbtkError("could not read image series : "< 0.) + { + spacingToBeSet = true; + spacingJPRx[0]= bbGetInputXSpacing(); + } + if (bbGetInputYSpacing() > 0.) + { + spacingToBeSet = true; + spacingJPRx[1]= bbGetInputYSpacing(); + } + if (bbGetInputZSpacing() > 0.) + { + spacingToBeSet = true; + spacingJPRx[2]= bbGetInputZSpacing(); + } + if (spacingToBeSet) + reader->GetOutput()->SetSpacing(spacingJPRx); + // JPRx + reader->GetOutput()->Register(); // if (bbGetOutputOut()) bbSetOutputOut ( reader->GetOutput() ); diff --git a/packages/itk/src/bbitkImageSeriesReader.h b/packages/itk/src/bbitkImageSeriesReader.h index 7f3337f..2c78ba5 100644 --- a/packages/itk/src/bbitkImageSeriesReader.h +++ b/packages/itk/src/bbitkImageSeriesReader.h @@ -2,8 +2,8 @@ Program: bbtk Module: $RCSfile: bbitkImageSeriesReader.h,v $ Language: C++ - Date: $Date: 2008/11/26 10:13:32 $ - Version: $Revision: 1.9 $ + Date: $Date: 2008/11/27 14:55:54 $ + Version: $Revision: 1.10 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -55,8 +55,18 @@ namespace bbitk BBTK_BLACK_BOX_INTERFACE(ImageSeriesReader, bbtk::AtomicBlackBox); - + //================================================================== + /// User callback called in the box contructor + virtual void bbUserConstructor(); + /// User callback called in the box copy constructor + virtual void bbUserCopyConstructor(bbtk::BlackBox::Pointer); + /// User callback called in the box destructor + virtual void bbUserDestructor(); + //================================================================== BBTK_DECLARE_INPUT(FileNames,std::vector); + BBTK_DECLARE_INPUT(XSpacing,float); + BBTK_DECLARE_INPUT(YSpacing,float); + BBTK_DECLARE_INPUT(ZSpacing,float); BBTK_DECLARE_OUTPUT(Out,anyImagePointer); BBTK_PROCESS(Read); void Read(); @@ -78,6 +88,10 @@ namespace bbitk typedef std::vector vectorofstring; BBTK_INPUT(ImageSeriesReader,FileNames, "vector of file names with complete paths",vectorofstring,"file names list"); + BBTK_INPUT(ImageSeriesReader,XSpacing, "if images don't contain information",float,""); + BBTK_INPUT(ImageSeriesReader,YSpacing, "if images don't contain information",float,"" ); + BBTK_INPUT(ImageSeriesReader,ZSpacing, "if images don't contain information",float,""); + BBTK_OUTPUT(ImageSeriesReader,Out,"Output itk::image with type T and dimension D determined by the content of the files + vector size",anyImagePointer,""); BBTK_END_DESCRIBE_BLACK_BOX(ImageSeriesReader); -- 2.47.1