]> Creatis software - bbtk.git/blob - packages/vtk/src/bbvtkUnMosaic.h
fcf808bb032f6180d76e7d0808ad1c7e0566cfe7
[bbtk.git] / packages / vtk / src / bbvtkUnMosaic.h
1 /*=========================================================================                                                                               
2   Program:   bbtk
3   Module:    $RCSfile: bbvtkUnMosaic.h,v $
4   Language:  C++
5   Date:      $Date: 2010/10/05 14:33:49 $
6   Version:   $Revision: 1.1 $
7 =========================================================================*/
8
9 /* ---------------------------------------------------------------------
10
11 * Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale)
12 * Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux
13 *
14 *  This software is governed by the CeCILL-B license under French law and 
15 *  abiding by the rules of distribution of free software. You can  use, 
16 *  modify and/ or redistribute the software under the terms of the CeCILL-B 
17 *  license as circulated by CEA, CNRS and INRIA at the following URL 
18 *  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html 
19 *  or in the file LICENSE.txt.
20 *
21 *  As a counterpart to the access to the source code and  rights to copy,
22 *  modify and redistribute granted by the license, users are provided only
23 *  with a limited warranty  and the software's author,  the holder of the
24 *  economic rights,  and the successive licensors  have only  limited
25 *  liability. 
26 *
27 *  The fact that you are presently reading this means that you have had
28 *  knowledge of the CeCILL-B license and that you accept its terms.
29 * ------------------------------------------------------------------------ */                                                                         
30
31 /**
32  * \brief Short description in one line
33  * 
34  * Long description which 
35  * can span multiple lines
36  */
37 /**
38  * \file 
39  * \brief Pattern for the definition of a new type of Node (header)
40  */
41 /**
42  * \class bbtk::NodePatern 
43  * \brief Pattern for the definition of a new type of Node 
44  */
45  
46 #ifdef _USE_VTK_
47
48 #ifndef __bbvtkUnMosaic_h_INCLUDED__
49 #define __bbvtkUnMosaic_h_INCLUDED__
50 #include "bbvtk_EXPORT.h"
51
52 #include "bbtkAtomicBlackBox.h"
53
54 #include "vtkImageData.h"
55
56 namespace bbvtk
57 {
58   class bbvtk_EXPORT UnMosaic : public bbtk::AtomicBlackBox
59   { 
60   public:
61     BBTK_BLACK_BOX_INTERFACE(UnMosaic, bbtk::AtomicBlackBox);
62     BBTK_DECLARE_INPUT (In,vtkImageData *);
63     BBTK_DECLARE_INPUT (NbImagesPerRow,int);
64     BBTK_DECLARE_INPUT (NbImagesInMosaic,int);       
65     BBTK_DECLARE_OUTPUT(Out, vtkImageData*);    
66     BBTK_PROCESS(Process);
67     void Process();
68   private :
69   vtkImageData * unMosaic(vtkImageData *imageIn, int nbImagesPerRow, int numberOfImagesInMosaic);
70   protected:
71   
72   // Attributes :
73   private:
74      vtkImageData *mImageOut;    
75   };
76
77   //=================================================================
78   // UserBlackBox description
79   BBTK_BEGIN_DESCRIBE_BLACK_BOX(UnMosaic,bbtk::AtomicBlackBox);
80   BBTK_NAME("UnMosaic");
81   BBTK_AUTHOR("jp at creatis.univ-lyon.fr");
82   BBTK_DESCRIPTION("Transforms a 2D (ala Siemens Mosaic) <vtkImageData*> into a 3D vtkImageData");
83   BBTK_CATEGORY("application, image");
84   BBTK_INPUT(UnMosaic, In, "ala Siemens Mosaic 2D image", vtkImageData *, "");
85   BBTK_INPUT(UnMosaic, NbImagesPerRow, "Nb of Images Per Row ", int, ""); 
86   BBTK_INPUT(UnMosaic, NbImagesInMosaic, "Nb of Images In Mosaic ", int, "");   
87   BBTK_OUTPUT(UnMosaic, Out, "3D Image", vtkImageData *, "");
88   BBTK_END_DESCRIBE_BLACK_BOX(UnMosaic);   
89   //=================================================================
90
91 }//namespace bbvtk
92    
93 #endif  //__bbtvtkUnMosaic_h__
94 #endif //_USE_VTK_