]> Creatis software - clitk.git/blob - vv/vvToolBinarize.h
binarize
[clitk.git] / vv / vvToolBinarize.h
1 /*=========================================================================
2
3   Program:   vv
4   Module:    $RCSfile: vvToolBinarize.h,v $
5   Language:  C++
6   Date:      $Date: 2010/02/07 08:49:42 $
7   Version:   $Revision: 1.4 $
8   Author :   David Sarrut (david.sarrut@creatis.insa-lyon.fr)
9
10   Copyright (C) 2010
11   Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
12   CREATIS                   http://www.creatis.insa-lyon.fr
13
14   This program is free software: you can redistribute it and/or modify
15   it under the terms of the GNU General Public License as published by
16   the Free Software Foundation, version 3 of the License.
17
18   This program is distributed in the hope that it will be useful,
19   but WITHOUT ANY WARRANTY; without even the implied warranty of
20   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21   GNU General Public License for more details.
22
23   You should have received a copy of the GNU General Public License
24   along with this program.  If not, see <http://www.gnu.org/licenses/>.
25
26   =========================================================================*/
27
28 #ifndef VVTOOLBINARIZE_H
29 #define VVTOOLBINARIZE_H
30
31 #include <QtDesigner/QDesignerExportWidget>
32 #include <QDialog>
33
34 #include "vvToolBase.h"
35 #include "vvImageContour.h"
36 #include "ui_vvToolBinarize.h"
37 #include "clitkBinarizeImage_ggo.h"
38
39 #include "vtkMarchingSquares.h"
40 #include "vtkImageClip.h"
41 #include "vtkMarchingCubes.h"
42 #include "vtkPolyData.h"
43 #include "vtkPolyDataMapper.h"
44 #include "vtkActor.h"
45 #include "vtkProperty.h"
46 #include "vtkRenderer.h"
47
48 //------------------------------------------------------------------------------
49 class vvToolBinarize:
50   public QDialog, public vvToolBase<vvToolBinarize>, private Ui::vvToolBinarize 
51 {
52   Q_OBJECT
53     public:
54   vvToolBinarize(QWidget * parent=0, Qt::WindowFlags f=0);
55   ~vvToolBinarize();
56
57   //-----------------------------------------------------
58   typedef vvToolBinarize Self;
59
60   //-----------------------------------------------------
61   static void Initialize() {
62     SetToolName("Binarize");
63     SetToolMenuName("Binarize");
64     SetToolIconFilename(":/new/prefix1/icons/binarize.png");
65     SetToolTip("Image interactive binarization with thresholds.");
66   }
67
68   void InputIsSet(bool b);
69   void GetArgsInfoFromGUI();
70
71   //-----------------------------------------------------
72  // public slots:
73 //   void InputUpdate();
74
75   public slots:
76   void apply();
77   // void InputChange(int index);
78   void valueChangedT1(double v);
79   void valueChangedT2(double v);
80   void UpdateSlice(int slicer,int slices);
81   void InputIsSelected();
82   void enableLowerThan(bool b);
83   void useFGBGtoggled(bool);
84
85  protected:
86   Ui::vvToolBinarize ui;
87   // std::vector<vvSlicerManager*> mSlicerManagers;
88 //   std::vector<vvSlicerManager*> mSlicerManagersCompatible;
89 //   vvImage::Pointer mCurrentImage;
90 //   vvSlicerManager * mCurrentSliceManager;
91   args_info_clitkBinarizeImage mArgsInfo;
92
93   vtkImageClip* mClipper;
94   vtkMarchingSquares* mSquares1;
95   vtkPolyDataMapper* mSquaresMapper1;
96   vtkActor* mSquaresActor1;
97
98   vvImageContour * mImageContour;
99
100   /* vtkImageClip* mClipper; */
101   /* vtkMarchingSquares* mSquares1; */
102   /* vtkPolyDataMapper* mSquaresMapper1; */
103   /* vtkActor* mSquaresActor1; */
104
105 }; // end class vvToolBinarize
106 //------------------------------------------------------------------------------
107
108 #endif
109