1 /*=========================================================================
2 Program: vv http://www.creatis.insa-lyon.fr/rio/vv
5 - University of LYON http://www.universite-lyon.fr/
6 - Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
7 - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr
9 This software is distributed WITHOUT ANY WARRANTY; without even
10 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11 PURPOSE. See the copyright notices for more information.
13 It is distributed under dual licence
15 - BSD See included LICENSE.txt file
16 - CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
17 ======================================================================-====*/
18 #include "vvToolBinarize.h"
19 #include "vvSlicerManager.h"
21 #include "vvToolInputSelectorWidget.h"
23 #include "clitkBinarizeImageGenericFilter.h"
25 #include <vtkImageActor.h>
26 #include <vtkCamera.h>
27 #include <vtkImageClip.h>
29 //------------------------------------------------------------------------------
30 // Create the tool and automagically (I like this word) insert it in
31 // the main window menu.
32 ADD_TOOL(vvToolBinarize);
33 //------------------------------------------------------------------------------
36 //------------------------------------------------------------------------------
37 void vvToolBinarize::Initialize() {
38 SetToolName("Binarize");
39 SetToolMenuName("Binarize");
40 SetToolIconFilename(":/new/prefix1/icons/binarize.png");
41 SetToolTip("Image interactive binarization with thresholds.");
43 //------------------------------------------------------------------------------
46 //------------------------------------------------------------------------------
47 vvToolBinarize::vvToolBinarize(vvMainWindowBase * parent, Qt::WindowFlags f)
48 :vvToolWidgetBase(parent,f),
49 vvToolBase<vvToolBinarize>(parent),
53 Ui_vvToolBinarize::setupUi(mToolWidget);
54 mInteractiveDisplayIsEnabled = mCheckBoxInteractiveDisplay->isChecked();
56 // Connect signals & slots
57 connect(mRadioButtonLowerThan, SIGNAL(toggled(bool)), this, SLOT(enableLowerThan(bool)));
58 connect(mCheckBoxUseFG, SIGNAL(toggled(bool)), this, SLOT(useFGBGtoggled(bool)));
59 connect(mCheckBoxUseBG, SIGNAL(toggled(bool)), this, SLOT(useFGBGtoggled(bool)));
60 connect(mCheckBoxInteractiveDisplay, SIGNAL(toggled(bool)), this, SLOT(InteractiveDisplayToggled(bool)));
62 // Initialize some widget
63 mThresholdSlider1->SetText("");
64 mThresholdSlider2->SetText("");
65 mFGSlider->SetText("Foreground value");
66 mBGSlider->SetText("Background value");
69 mFilter = new clitk::BinarizeImageGenericFilter<args_info_clitkBinarizeImage>;
71 // Set how many inputs are needed for this tool
72 AddInputSelector("Select one image", mFilter);
74 //------------------------------------------------------------------------------
77 //------------------------------------------------------------------------------
78 vvToolBinarize::~vvToolBinarize() {
80 //------------------------------------------------------------------------------
83 //------------------------------------------------------------------------------
84 void vvToolBinarize::InteractiveDisplayToggled(bool b) {
85 mInteractiveDisplayIsEnabled = b;
86 if (!mInteractiveDisplayIsEnabled) {
90 for(unsigned int i=0; i<mImageContour.size(); i++) {
91 mImageContour[i]->showActors();
92 if (mRadioButtonLowerThan->isChecked())
93 mImageContourLower[i]->showActors();
95 if (mCurrentSlicerManager)
96 mCurrentSlicerManager->Render();
99 //------------------------------------------------------------------------------
102 //------------------------------------------------------------------------------
103 void vvToolBinarize::RemoveVTKObjects() {
104 for(unsigned int i=0; i<mImageContour.size(); i++) {
105 mImageContour[i]->hideActors();
106 mImageContourLower[i]->hideActors();
108 if (mCurrentSlicerManager)
109 mCurrentSlicerManager->Render();
111 //------------------------------------------------------------------------------
114 //------------------------------------------------------------------------------
115 bool vvToolBinarize::close() {
117 return vvToolWidgetBase::close();
119 //------------------------------------------------------------------------------
122 //------------------------------------------------------------------------------
123 void vvToolBinarize::reject() {
124 // DD("vvToolBinarize::reject");
126 return vvToolWidgetBase::reject();
128 //------------------------------------------------------------------------------
131 //------------------------------------------------------------------------------
132 void vvToolBinarize::enableLowerThan(bool b) {
134 mThresholdSlider1->resetMaximum();
135 for(unsigned int i=0; i<mImageContour.size(); i++) {
136 mImageContourLower[i]->hideActors();
138 mCurrentSlicerManager->Render();
141 valueChangedT1(mThresholdSlider1->GetValue());
142 valueChangedT2(mThresholdSlider2->GetValue());
143 for(unsigned int i=0; i<mImageContour.size(); i++) {
144 mImageContourLower[i]->showActors();
146 mCurrentSlicerManager->Render();
149 //------------------------------------------------------------------------------
152 //------------------------------------------------------------------------------
153 void vvToolBinarize::useFGBGtoggled(bool) {
154 if (!mCheckBoxUseBG->isChecked() && !mCheckBoxUseFG->isChecked())
155 mCheckBoxUseBG->toggle();
157 //------------------------------------------------------------------------------
160 //------------------------------------------------------------------------------
161 // void vvToolBinarize::InputIsSelected(std::vector<vvSlicerManager *> & m) {
162 // DD("vvToolBinarize::InputIsSelected vector in binarize");
165 void vvToolBinarize::InputIsSelected(vvSlicerManager * m) {
166 mCurrentSlicerManager = m;
168 // Specific for this gui
169 mThresholdSlider1->SetValue(0);
170 mThresholdSlider2->SetValue(0);
171 mThresholdSlider1->SetImage(mCurrentImage);
172 mThresholdSlider2->SetImage(mCurrentImage);
173 mFGSlider->SetImage(mCurrentImage);
174 mBGSlider->SetImage(mCurrentImage);
175 // DD(mCurrentSlicerManager->GetFileName().c_str());
176 mFGSlider->SetMaximum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMax());
177 mFGSlider->SetMinimum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMin());
178 mBGSlider->SetMaximum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMax());
179 mBGSlider->SetMinimum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMin());
180 mFGSlider->SetValue(1);
181 mBGSlider->SetValue(0);
182 mFGSlider->SetSingleStep(1);
183 mBGSlider->SetSingleStep(1);
185 // VTK objects for interactive display
186 for(int i=0;i<mCurrentSlicerManager->NumberOfSlicers(); i++) {
187 mImageContour.push_back(new vvImageContour);
188 mImageContour[i]->setSlicer(mCurrentSlicerManager->GetSlicer(i));
189 mImageContour[i]->setColor(1.0, 0.0, 0.0);
190 mImageContourLower.push_back(new vvImageContour);
191 mImageContourLower[i]->setSlicer(mCurrentSlicerManager->GetSlicer(i));
192 mImageContourLower[i]->setColor(0.0, 0.0, 1.0);
194 valueChangedT1(mThresholdSlider1->GetValue());
196 connect(mThresholdSlider1, SIGNAL(valueChanged(double)), this, SLOT(valueChangedT1(double)));
197 connect(mThresholdSlider2, SIGNAL(valueChanged(double)), this, SLOT(valueChangedT2(double)));
199 connect(mCurrentSlicerManager,SIGNAL(UpdateSlice(int,int)),this,SLOT(UpdateSlice(int, int)));
200 connect(mCurrentSlicerManager,SIGNAL(UpdateTSlice(int,int)),this,SLOT(UpdateSlice(int, int)));
203 //------------------------------------------------------------------------------
206 //------------------------------------------------------------------------------
207 void vvToolBinarize::UpdateSlice(int slicer,int slices) {
208 if (!mInteractiveDisplayIsEnabled) return;
209 if (!mCurrentSlicerManager) close();
210 for(int i=0;i<mCurrentSlicerManager->NumberOfSlicers(); i++) {
211 mImageContour[i]->update(mThresholdSlider1->GetValue());
212 if (mRadioButtonLowerThan->isChecked())
213 mImageContourLower[i]->update(mThresholdSlider2->GetValue());
216 mCurrentSlicerManager->Render();
218 //------------------------------------------------------------------------------
220 //------------------------------------------------------------------------------
221 void vvToolBinarize::GetArgsInfoFromGUI() {
223 /* //KEEP THIS FOR READING GGO FROM FILE
225 std::string a = "toto";
226 char * const* argv = new char*;
228 struct cmdline_parser_params p;
229 p.check_required = 0;
230 int good = cmdline_parser_ext(argc, argv, &args_info, &p);
234 mArgsInfo.imagetypes_flag = 0;
235 mArgsInfo.upper_given = 0;
236 mArgsInfo.lower_given = 0;
237 bool inverseBGandFG = false;
239 mArgsInfo.lower_given = 1;
240 mArgsInfo.lower_arg = mThresholdSlider1->GetValue();
241 // DD(mArgsInfo.lower_arg);
242 if (mRadioButtonLowerThan->isChecked()) {
243 mArgsInfo.upper_given = 1;
244 mArgsInfo.upper_arg = mThresholdSlider2->GetValue();
245 if (mArgsInfo.upper_arg<mArgsInfo.lower_arg) {
246 mArgsInfo.upper_given = 0;
247 DD("TODO : lower thres greater than greater thres ! Ignoring ");
251 mArgsInfo.fg_arg = mFGSlider->GetValue();
252 mArgsInfo.bg_arg = mBGSlider->GetValue();
254 if (inverseBGandFG) {
255 mArgsInfo.fg_arg = mFGSlider->GetValue();
256 mArgsInfo.bg_arg = mBGSlider->GetValue();
258 mArgsInfo.fg_given = 1;
259 mArgsInfo.bg_given = 1;
261 if (mCheckBoxUseBG->isChecked()) {
262 if (mCheckBoxUseFG->isChecked()) mArgsInfo.mode_arg = (char*)"both";
263 else mArgsInfo.mode_arg = (char*)"BG";
265 else mArgsInfo.mode_arg = (char*)"FG";
267 mArgsInfo.verbose_flag = false;
269 // Required (even if not used)
270 mArgsInfo.input_given = 0;
271 mArgsInfo.output_given = 0;
273 mArgsInfo.input_arg = new char;
274 mArgsInfo.output_arg = new char;
276 //------------------------------------------------------------------------------
279 //------------------------------------------------------------------------------
280 void vvToolBinarize::apply() {
281 if (!mCurrentSlicerManager) close();
282 QApplication::setOverrideCursor(QCursor(Qt::WaitCursor));
283 GetArgsInfoFromGUI();
286 clitk::BinarizeImageGenericFilter<args_info_clitkBinarizeImage>::Pointer filter =
287 clitk::BinarizeImageGenericFilter<args_info_clitkBinarizeImage>::New();
288 filter->SetInputVVImage(mCurrentImage);
289 filter->SetArgsInfo(mArgsInfo);
290 filter->EnableReadOnDisk(false);
294 vvImage::Pointer output = filter->GetOutputVVImage();
295 std::ostringstream osstream;
296 osstream << "Binarized_" << mCurrentSlicerManager->GetSlicer(0)->GetFileName() << ".mhd";
297 AddImage(output,osstream.str());
298 QApplication::restoreOverrideCursor();
301 //------------------------------------------------------------------------------
304 //------------------------------------------------------------------------------
305 void vvToolBinarize::valueChangedT2(double v) {
306 // DD("valueChangedT2");
307 if (mRadioButtonLowerThan->isChecked()) {
308 mThresholdSlider1->SetMaximum(v);
309 if (!mInteractiveDisplayIsEnabled) return;
310 for(int i=0;i<mCurrentSlicerManager->NumberOfSlicers(); i++) {
311 mImageContourLower[i]->update(v);
313 mCurrentSlicerManager->Render();
316 //------------------------------------------------------------------------------
319 //------------------------------------------------------------------------------
320 void vvToolBinarize::valueChangedT1(double v) {
321 // DD("valueChangedT1");
322 if (!mCurrentSlicerManager) close();
323 mThresholdSlider2->SetMinimum(v);
324 // int m1 = (int)lrint(v);
325 if (!mInteractiveDisplayIsEnabled) return;
326 for(int i=0;i<mCurrentSlicerManager->NumberOfSlicers(); i++) {
327 mImageContour[i]->update(v);
329 mCurrentSlicerManager->Render();
331 //------------------------------------------------------------------------------