]> Creatis software - bbtk.git/blob - packages/itkvtk/src/bbitkvtkvtkImageData2itkImage.h
*** empty log message ***
[bbtk.git] / packages / itkvtk / src / bbitkvtkvtkImageData2itkImage.h
1 /*=========================================================================
2                                                                                 
3   Program:   bbtk
4   Module:    $RCSfile: bbitkvtkvtkImageData2itkImage.h,v $
5   Language:  C++
6   Date:      $Date: 2008/07/23 12:02:15 $
7   Version:   $Revision: 1.5 $
8                                                                                 
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.
12                                                                                 
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.
16                                                                                 
17 =========================================================================*/
18 /**
19  * \file 
20  * \brief class vtkImageData2itkImage : Converts a vtkImageData to a generic itkImage
21  */
22 /**
23  * \class vtkImageData2itkImage 
24  * \brief Converts a vtkImageData to a generic itkImage
25  */
26 #ifdef _USE_ITK_
27 #ifdef _USE_VTK_
28
29 #ifndef __bbitkvtkvtkImageData2itkImage_h__
30 #define __bbvitkvtktkImageData2itkImage_h__
31
32 #include "bbtkAtomicBlackBox.h"
33 #include "bbitkImage.h"
34 #include "vtkImageData.h"
35 #include "itkProcessObject.h"
36
37 namespace bbitkvtk
38 {
39   
40   class /*BBTK_EXPORT*/ vtkImageData2itkImage : public bbtk::AtomicBlackBox  
41   {
42     
43     BBTK_BLACK_BOX_INTERFACE(vtkImageData2itkImage,
44                              bbtk::AtomicBlackBox);
45
46     BBTK_DECLARE_INPUT(In,vtkImageData*);
47     BBTK_DECLARE_OUTPUT(Out,bbitk::anyImagePointer);
48     BBTK_PROCESS(Convert);
49     void Convert();
50     void bbUserConstructor();
51     void bbUserCopyConstructor();
52     void bbUserDestructor();
53
54   private:
55     // Convert method : template on type of the itk image to be created
56     template<class T, unsigned int D> void Convert();
57     // stores the pointer on the template itk::VTKImageToImageFilter 
58     itk::ProcessObject::Pointer mConverter;
59   }; 
60   
61
62   //=================================================================
63   // AtomicBlackBox description
64   BBTK_BEGIN_DESCRIBE_BLACK_BOX(vtkImageData2itkImage,bbtk::AtomicBlackBox);
65   BBTK_NAME("vtkImageData2itkImage");
66   BBTK_AUTHOR("laurent.guigues@creatis.insa-lyon.fr");
67   BBTK_DESCRIPTION("Converts a vtkImageData* to a generic itkImage pointer");
68   BBTK_DEFAULT_ADAPTOR();
69   BBTK_INPUT(vtkImageData2itkImage,In,
70              "Input vtkImageData",vtkImageData*,"");
71   BBTK_OUTPUT(vtkImageData2itkImage,Out,
72               "Output itkImage",
73               bbitk::anyImagePointer,"");
74   BBTK_END_DESCRIBE_BLACK_BOX(vtkImageData2itkImage);
75   //=================================================================
76   
77
78 }
79 //namespace bbitkvtk
80 #endif
81 // _USE_VTK_
82 #endif
83 // _USE_ITK_
84
85 #endif