X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=common%2FclitkCommonGenericFilter.h;h=4826263dc65faf6318620272f9ae95bd6120f095;hb=8973673f3f984656ec3552b5d963ba7b18119d39;hp=751a7262a63b1a97122658ccb93eba3c441e8de1;hpb=8186ce7844751ffa0bd43e8a6ed53d1cc050b843;p=clitk.git diff --git a/common/clitkCommonGenericFilter.h b/common/clitkCommonGenericFilter.h index 751a726..4826263 100644 --- a/common/clitkCommonGenericFilter.h +++ b/common/clitkCommonGenericFilter.h @@ -3,8 +3,8 @@ Program: clitk Module: $RCSfile: clitkCommonGenericFilter.h,v $ Language: C++ - Date: $Date: 2010/01/29 08:48:42 $ - Version: $Revision: 1.1 $ + Date: $Date: 2010/02/09 14:19:28 $ + Version: $Revision: 1.3 $ Author : Joel Schaerer David Sarrut @@ -45,18 +45,16 @@ namespace clitk { class GenericFilterFunctorBase { public: GenericFilterFunctorBase(FilterType * f) { mFilter = f; } - virtual void DoIt()= 0; + virtual void Execute()= 0; FilterType * mFilter; }; //-------------------------------------------------------------------- - template + template class GenericFilterFunctorWithDimAndPixelType: public GenericFilterFunctorBase { public: GenericFilterFunctorWithDimAndPixelType(FilterType * f): GenericFilterFunctorBase(f) {} - virtual void DoIt() { - //GenericFilterFunctorBase::mFilter->template UpdateWithDimAndPixelType(); - typedef itk::Image InputImageType; + virtual void Execute() { GenericFilterFunctorBase::mFilter->template UpdateWithInputImageType(); } }; @@ -66,20 +64,28 @@ namespace clitk { class ImageTypesManager { public: typedef std::map*> MapOfPixelTypeToFunctionType; - std::map mMapOfImageTypeToFunction; + typedef std::map MapOfImageComponentsToFunctionType; + typedef std::map MapOfImageDimensionToFunctionType; + MapOfImageDimensionToFunctionType mMapOfImageTypeToFunction; ImageTypesManager(FilterType * f) { mFilter = f; } - virtual void DoIt(int dim, std::string pixelname) { + virtual void DoIt(int dim, int ncomp, std::string pixelname) { // std::cout << "ImageTypesManager DoIt " << dim << " " << pixelname << std::endl; - if (mMapOfImageTypeToFunction[dim][pixelname]) - mMapOfImageTypeToFunction[dim][pixelname]->DoIt(); + if (mMapOfImageTypeToFunction[dim][ncomp][pixelname]) + mMapOfImageTypeToFunction[dim][ncomp][pixelname]->Execute(); } - template + template void AddNewDimensionAndPixelType() { - // std::cout << "Adding Dim=" << Dim << " and PT = " << GetTypeAsString() << std::endl; - mFilter->AddImageType(Dim, GetTypeAsString()); - mMapOfImageTypeToFunction[Dim][ GetTypeAsString() ] = - new GenericFilterFunctorWithDimAndPixelType(mFilter); + typedef itk::Image,Dim> InputImageType; + mMapOfImageTypeToFunction[Dim][NComp][ GetTypeAsString() ] = + new GenericFilterFunctorWithDimAndPixelType(mFilter); + } + /// Specialization for NComp == 1 + template + void AddNewDimensionAndPixelType() { + typedef itk::Image InputImageType; + mMapOfImageTypeToFunction[Dim][1][ GetTypeAsString() ] = + new GenericFilterFunctorWithDimAndPixelType(mFilter); } FilterType * mFilter; };