1 /*=========================================================================
4 Module: $RCSfile: vvToolBinarize.h,v $
6 Date: $Date: 2010/02/24 11:42:42 $
7 Version: $Revision: 1.6 $
8 Author : David Sarrut (david.sarrut@creatis.insa-lyon.fr)
11 Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
12 CREATIS http://www.creatis.insa-lyon.fr
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.
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.
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/>.
26 =========================================================================*/
28 #ifndef VVTOOLBINARIZE_H
29 #define VVTOOLBINARIZE_H
31 #include <QtDesigner/QDesignerExportWidget>
34 #include "vvToolBase.h"
35 #include "vvToolWidgetBase.h"
36 #include "vvImageContour.h"
37 #include "ui_vvToolBinarize.h"
38 #include "clitkBinarizeImage_ggo.h"
40 #include "vtkMarchingSquares.h"
41 #include "vtkImageClip.h"
42 #include "vtkMarchingCubes.h"
43 #include "vtkPolyData.h"
44 #include "vtkPolyDataMapper.h"
46 #include "vtkProperty.h"
47 #include "vtkRenderer.h"
49 //------------------------------------------------------------------------------
51 public vvToolWidgetBase,
52 public vvToolBase<vvToolBinarize>,
53 private Ui::vvToolBinarize
57 vvToolBinarize(vvMainWindowBase * parent=0, Qt::WindowFlags f=0);
60 //-----------------------------------------------------
61 static void Initialize();
62 void InputIsSet(bool b);
63 void GetArgsInfoFromGUI();
65 //-----------------------------------------------------
68 void valueChangedT1(double v);
69 void valueChangedT2(double v);
70 void UpdateSlice(int slicer,int slices);
71 void InputIsSelected(vvSlicerManager * m);
72 void enableLowerThan(bool b);
73 void useFGBGtoggled(bool);
74 virtual bool close() { DD("vvToolBinarize::close");
75 for(unsigned int i=0; i<mImageContour.size(); i++)
76 mImageContour[i]->removeActors();
77 if (mCurrentSlicerManager)
78 mCurrentSlicerManager->Render();
79 return vvToolWidgetBase::close(); }
81 virtual void reject() { DD("vvToolBinarize::reject");
82 for(unsigned int i=0; i<mImageContour.size(); i++)
83 mImageContour[i]->removeActors();
84 if (mCurrentSlicerManager)
85 mCurrentSlicerManager->Render();
86 return vvToolWidgetBase::reject(); }
90 Ui::vvToolBinarize ui;
91 args_info_clitkBinarizeImage mArgsInfo;
92 std::vector<vvImageContour*> mImageContour;
94 }; // end class vvToolBinarize
95 //------------------------------------------------------------------------------