]> Creatis software - clitk.git/blobdiff - tools/clitkSplitImageGenericFilter.h
Change header includion from .h to .cxx file
[clitk.git] / tools / clitkSplitImageGenericFilter.h
old mode 100755 (executable)
new mode 100644 (file)
index 9c34e9d..4b6d676
@@ -3,7 +3,7 @@
 
   Authors belong to: 
   - University of LYON              http://www.universite-lyon.fr/
-  - Léon Bérard cancer center       http://oncora1.lyon.fnclcc.fr
+  - Léon Bérard cancer center       http://www.centreleonberard.fr
   - CREATIS CNRS laboratory         http://www.creatis.insa-lyon.fr
 
   This software is distributed WITHOUT ANY WARRANTY; without even
@@ -14,7 +14,7 @@
 
   - BSD        See included LICENSE.txt file
   - CeCILL-B   http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
-======================================================================-====*/
+===========================================================================**/
 #ifndef clitkSplitImageGenericFilter_H
 #define clitkSplitImageGenericFilter_H
 /**
@@ -67,6 +67,23 @@ namespace clitk {
     void UpdateWithInputImageType();
 
   protected:  
+    template <class ImageType>
+    class PngConversion
+    {
+    public:
+      typedef typename ImageType::Pointer ImagePointer;
+      typedef itk::Image< unsigned char, ImageType::ImageDimension > OutputPngImageType;
+      typedef typename OutputPngImageType::Pointer OutputPngImagePointer;
+      OutputPngImagePointer Do(double window, double level, ImagePointer input);
+    private:
+      template<unsigned int> struct PixelDimType {};
+      template<unsigned int Dim> OutputPngImagePointer Do(double window,
+                                                          double level,
+                                                          ImagePointer input,
+                                                          PixelDimType<Dim> *);
+      OutputPngImagePointer Do(double window, double level, ImagePointer input, PixelDimType<1> *);
+    };
+
     template<unsigned int Dim> void InitializeImageType();
     int  mSplitDimension;
     bool m_Verbose;