]> Creatis software - creaVtk.git/blob - lib/creaVtk/cutImageSegmentation.h
#2660 creaVtk Feature New Normal - New cutImageSegmentation
[creaVtk.git] / lib / creaVtk / cutImageSegmentation.h
1 /*
2 # ---------------------------------------------------------------------
3 #
4 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5 #                        pour la Sante)
6 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
7 # Previous Authors : Laurent Guigues, Jean-Pierre Roux
8 # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9 #
10 #  This software is governed by the CeCILL-B license under French law and
11 #  abiding by the rules of distribution of free software. You can  use,
12 #  modify and/ or redistribute the software under the terms of the CeCILL-B
13 #  license as circulated by CEA, CNRS and INRIA at the following URL
14 #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
15 #  or in the file LICENSE.txt.
16 #
17 #  As a counterpart to the access to the source code and  rights to copy,
18 #  modify and redistribute granted by the license, users are provided only
19 #  with a limited warranty  and the software's author,  the holder of the
20 #  economic rights,  and the successive licensors  have only  limited
21 #  liability.
22 #
23 #  The fact that you are presently reading this means that you have had
24 #  knowledge of the CeCILL-B license and that you accept its terms.
25 # ------------------------------------------------------------------------
26 */
27
28 #ifndef _CUTIMAGESEGMENTATION_H_
29 #define _CUTIMAGESEGMENTATION_H_
30
31 #include "vtkImageData.h"
32 #include "vtkPolyData.h"
33 #include "vtkLinearExtrusionFilter.h"
34 #include "vtkPolyDataToImageStencil.h"
35 #include "vtkImageStencil.h"
36 //#include "vtkExtractVOI.h"
37 #include "vtkAppendPolyData.h"
38 //#include "vtkTriangleFilter"
39 #include "vtkStripper.h"
40 #include "vtkTransformPolyDataFilter.h"
41 #include <vector>
42 //#include <math.h>
43
44 //#include "HeartAngles.h"
45 //---------------------------------------------
46 // Class Name: cutImageSegmentation
47 // [classdescription]
48 //---------------------------------------------
49
50 class cutImageSegmentation
51 {
52
53 //---------------------------------------------
54 //Methods and attributes exposed to other classes
55 //---------------------------------------------
56 public :
57   cutImageSegmentation();
58   ~cutImageSegmentation();
59
60   void SetAnglesImage ( vtkImageData* image );
61   void SetMesh1 ( vtkPolyData* mesh );
62   
63   vtkImageData* GetResultImage();
64  
65   void Process();
66   
67
68 //--Method template----------------------------
69 //  void FunctionName(int& parameterA);
70
71
72 //---------------------------------------------
73 //Methods and attributes exposed only to classes
74 //that are derived from this class
75 //---------------------------------------------
76 protected:
77
78 //---------------------------------------------
79 //Methods and attributes only visible by this class
80 //---------------------------------------------
81 private:
82
83         vtkImageData* m_Image;
84   vtkPolyData* m_Mesh1;
85
86         vtkImageData* m_ResultImage;
87
88         //HeartAngles ha;
89 };
90
91 //-end of _cutImageSegmentation_H_------------------------------------------------------
92 #endif