]> Creatis software - cpPlugins.git/blobdiff - lib/cpPlugins/Interface/Image.hxx
Merge branch 'master' of ssh://git.creatis.insa-lyon.fr/cpPlugins
[cpPlugins.git] / lib / cpPlugins / Interface / Image.hxx
index bb1c667bf30af84bc91df05d8e38723728d12ffd..b6794a36bcdb1d3bc582db225ab6d2f8f6481dee 100644 (file)
@@ -1,7 +1,8 @@
 #ifndef __CPPLUGINS__INTERFACE__IMAGE__HXX__
 #define __CPPLUGINS__INTERFACE__IMAGE__HXX__
 
-#define ITK_MANUAL_INSTANTIATION
+#include <cpPlugins/Interface/Macros.h>
+
 #include <itkImage.h>
 #include <itkImageToVTKImageFilter.h>
 
     TI, itk::SymmetricSecondRankTensor, double, D, D, o                 \
     )
 
+// -------------------------------------------------------------------------
+#define cpPlugins_Image_Import( T, D )                                  \
+  cpPlugins_TEMPLATE_IMPORT(                                            \
+    2(class cpPlugins_Interface_EXPORT itk::Image< T, D >)              \
+    )
+
+// -------------------------------------------------------------------------
+#define cpPlugins_VTKImage_Import( T, D )                               \
+  cpPlugins_TEMPLATE_IMPORT(                                            \
+    2(                                                                  \
+      class cpPlugins_Interface_EXPORT                                  \
+      itk::ImageToVTKImageFilter< itk::Image< T, D > >                  \
+      )                                                                 \
+    )
+
+// -------------------------------------------------------------------------
+#define cpPlugins_ImageArray_Import( A, T, DA, DI )                     \
+  cpPlugins_TEMPLATE_IMPORT(                                            \
+    3(                                                                  \
+      class cpPlugins_Interface_EXPORT                                  \
+      itk::Image< itk::A< T, DA >, DI >                                 \
+      )                                                                 \
+    )
+
+// -------------------------------------------------------------------------
+#define cpPlugins_VTKImageArray_Import( A, T, DA, DI )                  \
+  cpPlugins_TEMPLATE_IMPORT(                                            \
+    3(                                                                  \
+      class cpPlugins_Interface_EXPORT                                  \
+      itk::ImageToVTKImageFilter< itk::Image< itk::A< T, DA >, DI > >   \
+      )                                                                 \
+    )
+
+// -------------------------------------------------------------------------
+#define cpPlugins_Image_Import_AllDimensions( T )       \
+  cpPlugins_Image_Import( T, 2 );                       \
+  cpPlugins_Image_Import( T, 3 );                       \
+  cpPlugins_Image_Import( T, 4 )
+
+// -------------------------------------------------------------------------
+#define cpPlugins_VTKImage_Import_AllDimensions( T )       \
+  cpPlugins_VTKImage_Import( T, 2 );                       \
+  cpPlugins_VTKImage_Import( T, 3 )
+
+// -------------------------------------------------------------------------
+#define cpPlugins_ImageArray_Import_AllDimensions( A, T )             \
+  cpPlugins_ImageArray_Import( A, T, 2, 2 );                          \
+  cpPlugins_ImageArray_Import( A, T, 3, 3 );                          \
+  cpPlugins_ImageArray_Import( A, T, 4, 4 )
+
+// -------------------------------------------------------------------------
+#define cpPlugins_VTKImageArray_Import_AllDimensions( A, T )            \
+  cpPlugins_VTKImageArray_Import( A, T, 2, 2 );                         \
+  cpPlugins_VTKImageArray_Import( A, T, 3, 3 )
+
+// -------------------------------------------------------------------------
+// ITK base clases
+
+#ifndef cpPlugins_Interface_EXPORTS
+
+cpPlugins_Image_Import_AllDimensions( char );
+cpPlugins_Image_Import_AllDimensions( short );
+cpPlugins_Image_Import_AllDimensions( int );
+cpPlugins_Image_Import_AllDimensions( long );
+cpPlugins_Image_Import_AllDimensions( unsigned char );
+cpPlugins_Image_Import_AllDimensions( unsigned short );
+cpPlugins_Image_Import_AllDimensions( unsigned int );
+cpPlugins_Image_Import_AllDimensions( unsigned long );
+cpPlugins_Image_Import_AllDimensions( float );
+cpPlugins_Image_Import_AllDimensions( double );
+
+cpPlugins_Image_Import_AllDimensions( std::complex< float > );
+cpPlugins_Image_Import_AllDimensions( std::complex< double > );
+
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< char > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< short > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< int > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< long > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< unsigned char > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< unsigned short > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< unsigned int > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBPixel< unsigned long > );
+
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< char > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< short > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< int > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< long > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< unsigned char > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< unsigned short > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< unsigned int > );
+cpPlugins_Image_Import_AllDimensions( itk::RGBAPixel< unsigned long > );
+
+cpPlugins_ImageArray_Import_AllDimensions( Vector, float );
+cpPlugins_ImageArray_Import_AllDimensions( Vector, double );
+
+cpPlugins_ImageArray_Import_AllDimensions( CovariantVector, float );
+cpPlugins_ImageArray_Import_AllDimensions( CovariantVector, double );
+
+cpPlugins_ImageArray_Import_AllDimensions( Point, float );
+cpPlugins_ImageArray_Import_AllDimensions( Point, double );
+
+cpPlugins_ImageArray_Import_AllDimensions(
+  SymmetricSecondRankTensor, float
+  );
+cpPlugins_ImageArray_Import_AllDimensions(
+  SymmetricSecondRankTensor, double
+  );
+
+cpPlugins_Image_Import( itk::DiffusionTensor3D< float >, 3 );
+cpPlugins_Image_Import( itk::DiffusionTensor3D< double >, 3 );
+cpPlugins_Image_Import( itk::Offset< 2 >, 2 );
+cpPlugins_Image_Import( itk::Offset< 3 >, 3 );
+cpPlugins_Image_Import( itk::Offset< 4 >, 4 );
+
+// -------------------------------------------------------------------------
+// ITK<->VTK base clases
+cpPlugins_VTKImage_Import_AllDimensions( char );
+cpPlugins_VTKImage_Import_AllDimensions( short );
+cpPlugins_VTKImage_Import_AllDimensions( int );
+cpPlugins_VTKImage_Import_AllDimensions( long );
+cpPlugins_VTKImage_Import_AllDimensions( unsigned char );
+cpPlugins_VTKImage_Import_AllDimensions( unsigned short );
+cpPlugins_VTKImage_Import_AllDimensions( unsigned int );
+cpPlugins_VTKImage_Import_AllDimensions( unsigned long );
+cpPlugins_VTKImage_Import_AllDimensions( float );
+cpPlugins_VTKImage_Import_AllDimensions( double );
+
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< char > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< short > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< int > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< long > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< unsigned char > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< unsigned short > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< unsigned int > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< unsigned long > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< float > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBPixel< double > );
+
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< char > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< short > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< int > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< long > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< unsigned char > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< unsigned short > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< unsigned int > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< unsigned long > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< float > );
+cpPlugins_VTKImage_Import_AllDimensions( itk::RGBAPixel< double > );
+
+cpPlugins_VTKImageArray_Import_AllDimensions( Vector, float );
+cpPlugins_VTKImageArray_Import_AllDimensions( Vector, double );
+
+cpPlugins_VTKImageArray_Import_AllDimensions( CovariantVector, float );
+cpPlugins_VTKImageArray_Import_AllDimensions( CovariantVector, double );
+
+cpPlugins_VTKImageArray_Import_AllDimensions( Point, float );
+cpPlugins_VTKImageArray_Import_AllDimensions( Point, double );
+
+cpPlugins_VTKImageArray_Import_AllDimensions(
+  SymmetricSecondRankTensor, float
+  );
+cpPlugins_VTKImageArray_Import_AllDimensions(
+  SymmetricSecondRankTensor, double
+  );
+
+cpPlugins_VTKImage_Import( itk::DiffusionTensor3D< float >, 3 );
+cpPlugins_VTKImage_Import( itk::DiffusionTensor3D< double >, 3 );
+
+#endif // cpPlugins_Interface_EXPORTS
+
 // -------------------------------------------------------------------------
 template< class I >
 void cpPlugins::Interface::Image::