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://www.centreleonberard.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 ===========================================================================**/
20 #include "vvToolProfile.h"
21 #include "vvSlicerManager.h"
23 #include "vvToolInputSelectorWidget.h"
26 #include "clitkProfileImageGenericFilter.h"
29 #include <vtkImageActor.h>
30 #include <vtkCamera.h>
31 #include <vtkImageClip.h>
32 #include <vtkRenderWindow.h>
35 //------------------------------------------------------------------------------
36 // Create the tool and automagically (I like this word) insert it in
37 // the main window menu.
38 ADD_TOOL(vvToolProfile);
39 //------------------------------------------------------------------------------
42 //------------------------------------------------------------------------------
43 void vvToolProfile::Initialize()
45 SetToolName("Profile");
46 SetToolMenuName("Intensity Profile");
47 SetToolIconFilename(":/common/icons/profile.png");
48 SetToolTip("Display the intensity profile between 2 points of the image.");
49 SetToolExperimental(false);
51 //------------------------------------------------------------------------------
54 //------------------------------------------------------------------------------
55 vvToolProfile::vvToolProfile(vvMainWindowBase * parent, Qt::WindowFlags f)
56 :vvToolWidgetBase(parent,f),
57 vvToolBase<vvToolProfile>(parent),
61 Ui_vvToolProfile::setupUi(mToolWidget);
62 mInteractiveDisplayIsEnabled = mCheckBoxInteractiveDisplay->isChecked();
64 // Connect signals & slots
65 connect(mRadioButtonLowerThan, SIGNAL(toggled(bool)), this, SLOT(enableLowerThan(bool)));
66 connect(mCheckBoxUseFG, SIGNAL(toggled(bool)), this, SLOT(useFGBGtoggled(bool)));
67 connect(mCheckBoxUseBG, SIGNAL(toggled(bool)), this, SLOT(useFGBGtoggled(bool)));
68 connect(mCheckBoxInteractiveDisplay, SIGNAL(toggled(bool)), this, SLOT(InteractiveDisplayToggled(bool)));
70 // Initialize some widget
71 mThresholdSlider1->SetText("");
72 mThresholdSlider2->SetText("");
73 mFGSlider->SetText("Foreground value");
74 mBGSlider->SetText("Background value");
77 mFilter = clitk::ProfileImageGenericFilter::New();
79 // Set how many inputs are needed for this tool
80 AddInputSelector("Select one image", mFilter);
82 //------------------------------------------------------------------------------
85 //------------------------------------------------------------------------------
86 vvToolProfile::~vvToolProfile()
89 //------------------------------------------------------------------------------
92 //------------------------------------------------------------------------------
93 void vvToolProfile::InteractiveDisplayToggled(bool b)
95 mInteractiveDisplayIsEnabled = b;
96 if (!mInteractiveDisplayIsEnabled) {
99 for(unsigned int i=0; i<mImageContour.size(); i++) {
100 mImageContour[i]->ShowActors();
101 if (mRadioButtonLowerThan->isChecked())
102 mImageContourLower[i]->ShowActors();
104 if (mCurrentSlicerManager)
105 mCurrentSlicerManager->Render();
108 //------------------------------------------------------------------------------
111 //------------------------------------------------------------------------------
112 void vvToolProfile::RemoveVTKObjects()
114 for(unsigned int i=0; i<mImageContour.size(); i++) {
115 mImageContour[i]->HideActors();
116 mImageContourLower[i]->HideActors();
118 if (mCurrentSlicerManager)
119 mCurrentSlicerManager->Render();
121 //------------------------------------------------------------------------------
124 //------------------------------------------------------------------------------
125 bool vvToolProfile::close()
127 // RemoveVTKObjects();
128 return vvToolWidgetBase::close();
130 //------------------------------------------------------------------------------
133 //------------------------------------------------------------------------------
134 void vvToolProfile::closeEvent(QCloseEvent *event)
139 //------------------------------------------------------------------------------
142 //------------------------------------------------------------------------------
143 void vvToolProfile::reject()
145 // DD("vvToolProfile::reject");
147 return vvToolWidgetBase::reject();
149 //------------------------------------------------------------------------------
152 //------------------------------------------------------------------------------
153 void vvToolProfile::enableLowerThan(bool b)
156 mThresholdSlider1->resetMaximum();
157 for(unsigned int i=0; i<mImageContour.size(); i++) {
158 mImageContourLower[i]->HideActors();
160 mCurrentSlicerManager->Render();
162 valueChangedT1(mThresholdSlider1->GetValue());
163 valueChangedT2(mThresholdSlider2->GetValue());
164 for(unsigned int i=0; i<mImageContour.size(); i++) {
165 mImageContourLower[i]->ShowActors();
167 mCurrentSlicerManager->Render();
170 //------------------------------------------------------------------------------
173 //------------------------------------------------------------------------------
174 void vvToolProfile::useFGBGtoggled(bool)
176 if (!mCheckBoxUseBG->isChecked() && !mCheckBoxUseFG->isChecked())
177 mCheckBoxUseBG->toggle();
179 //------------------------------------------------------------------------------
182 //------------------------------------------------------------------------------
183 // void vvToolProfile::InputIsSelected(std::vector<vvSlicerManager *> & m) {
184 // DD("vvToolProfile::InputIsSelected vector in Profile");
187 void vvToolProfile::InputIsSelected(vvSlicerManager * m)
189 mCurrentSlicerManager = m;
191 // Specific for this gui
192 mThresholdSlider1->SetValue(0);
193 mThresholdSlider2->SetValue(0);
194 mThresholdSlider1->SetImage(mCurrentImage);
195 mThresholdSlider2->SetImage(mCurrentImage);
196 mFGSlider->SetImage(mCurrentImage);
197 mBGSlider->SetImage(mCurrentImage);
198 // DD(mCurrentSlicerManager->GetFileName().c_str());
199 // mFGSlider->SetMaximum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMax());
200 // mFGSlider->SetMinimum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMin());
201 // mBGSlider->SetMaximum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMax());
202 // mBGSlider->SetMinimum(mCurrentImage->GetFirstVTKImageData()->GetScalarTypeMin());
204 // Output is uchar ...
205 mFGSlider->SetMaximum(255);
206 mFGSlider->SetMinimum(0);
207 mBGSlider->SetMaximum(255);
208 mBGSlider->SetMinimum(0);
210 mFGSlider->SetValue(1);
211 mBGSlider->SetValue(0);
212 mFGSlider->SetSingleStep(1);
213 mBGSlider->SetSingleStep(1);
215 // VTK objects for interactive display
216 for(int i=0; i<mCurrentSlicerManager->GetNumberOfSlicers(); i++) {
217 mImageContour.push_back(vvImageContour::New());
218 mImageContour[i]->SetSlicer(mCurrentSlicerManager->GetSlicer(i));
219 mImageContour[i]->SetColor(1.0, 0.0, 0.0);
220 mImageContour[i]->SetDepth(0); // to be in front of (whe used with ROI tool)
221 mImageContourLower.push_back(vvImageContour::New());
222 mImageContourLower[i]->SetSlicer(mCurrentSlicerManager->GetSlicer(i));
223 mImageContourLower[i]->SetColor(0.0, 0.0, 1.0);
224 mImageContourLower[i]->SetDepth(100); // to be in front of (whe used with ROI tool)
226 valueChangedT1(mThresholdSlider1->GetValue());
228 connect(mThresholdSlider1, SIGNAL(valueChanged(double)), this, SLOT(valueChangedT1(double)));
229 connect(mThresholdSlider2, SIGNAL(valueChanged(double)), this, SLOT(valueChangedT2(double)));
231 connect(mCurrentSlicerManager,SIGNAL(UpdateSlice(int,int)),this,SLOT(UpdateSlice(int, int)));
232 connect(mCurrentSlicerManager,SIGNAL(UpdateTSlice(int,int)),this,SLOT(UpdateSlice(int, int)));
234 connect(mCurrentSlicerManager,SIGNAL(UpdateOrientation(int,int)),this,SLOT(UpdateOrientation(int, int)));
236 // connect(mCurrentSlicerManager, SIGNAL(LeftButtonReleaseSignal(int)), SLOT(LeftButtonReleaseEvent(int)));
237 InteractiveDisplayToggled(mInteractiveDisplayIsEnabled);
239 //------------------------------------------------------------------------------
242 //------------------------------------------------------------------------------
243 // void vvToolProfile::LeftButtonReleaseEvent(int slicer) {
244 // DD("LeftButtonReleaseEvent");
245 // for(int i=0; i<mCurrentSlicerManager->GetNumberOfSlicers(); i++) {
247 // mCurrentSlicerManager->GetSlicer(i)->GetRenderWindow()->Render();
250 //------------------------------------------------------------------------------
253 //------------------------------------------------------------------------------
254 void vvToolProfile::UpdateOrientation(int slicer,int orientation)
258 //------------------------------------------------------------------------------
260 //------------------------------------------------------------------------------
261 void vvToolProfile::UpdateSlice(int slicer,int slices)
265 //------------------------------------------------------------------------------
267 //------------------------------------------------------------------------------
268 void vvToolProfile::Update(int slicer)
270 if (!mInteractiveDisplayIsEnabled) return;
271 if (!mCurrentSlicerManager) close();
272 mImageContour[slicer]->Update(mThresholdSlider1->GetValue());
273 if (mRadioButtonLowerThan->isChecked())
274 mImageContourLower[slicer]->Update(mThresholdSlider2->GetValue());
276 //------------------------------------------------------------------------------
278 //------------------------------------------------------------------------------
279 void vvToolProfile::GetArgsInfoFromGUI()
282 /* //KEEP THIS FOR READING GGO FROM FILE
284 std::string a = "toto";
285 char * const* argv = new char*;
287 struct cmdline_parser_params p;
288 p.check_required = 0;
289 int good = cmdline_parser_ext(argc, argv, &args_info, &p);
292 cmdline_parser_clitkProfileImage_init(&mArgsInfo); // Initialisation to default
293 bool inverseBGandFG = false;
295 mArgsInfo.lower_given = 1;
296 mArgsInfo.lower_arg = mThresholdSlider1->GetValue();
297 if (mRadioButtonLowerThan->isChecked()) {
298 mArgsInfo.upper_given = 1;
299 mArgsInfo.upper_arg = mThresholdSlider2->GetValue();
300 if (mArgsInfo.upper_arg<mArgsInfo.lower_arg) {
301 mArgsInfo.upper_given = 0;
302 DD("TODO : lower thres greater than greater thres ! Ignoring ");
306 mArgsInfo.fg_arg = mFGSlider->GetValue();
307 mArgsInfo.bg_arg = mBGSlider->GetValue();
309 if (inverseBGandFG) {
310 mArgsInfo.fg_arg = mFGSlider->GetValue();
311 mArgsInfo.bg_arg = mBGSlider->GetValue();
313 mArgsInfo.fg_given = 1;
314 mArgsInfo.bg_given = 1;
316 if (mCheckBoxUseBG->isChecked()) {
317 if (mCheckBoxUseFG->isChecked()) mArgsInfo.mode_arg = (char*)"both";
318 else mArgsInfo.mode_arg = (char*)"BG";
319 } else mArgsInfo.mode_arg = (char*)"FG";
321 mArgsInfo.verbose_flag = false;
323 // // Required (even if not used)
324 // mArgsInfo.input_given = 0;
325 // mArgsInfo.output_given = 0;
327 // mArgsInfo.input_arg = new char;
328 // mArgsInfo.output_arg = new char;
330 //------------------------------------------------------------------------------
333 //------------------------------------------------------------------------------
334 void vvToolProfile::apply()
336 if (!mCurrentSlicerManager) close();
337 QApplication::setOverrideCursor(QCursor(Qt::WaitCursor));
338 GetArgsInfoFromGUI();
341 clitk::ProfileImageGenericFilter::Pointer filter =
342 clitk::ProfileImageGenericFilter::New();
343 filter->SetInputVVImage(mCurrentImage);
344 filter->SetArgsInfo(mArgsInfo);
349 vvImage::Pointer output = filter->GetOutputVVImage();
350 std::ostringstream osstream;
351 osstream << "Profiled_" << mCurrentSlicerManager->GetSlicer(0)->GetFileName() << ".mhd";
352 AddImage(output,osstream.str());
353 QApplication::restoreOverrideCursor();
356 //------------------------------------------------------------------------------
359 //------------------------------------------------------------------------------
360 void vvToolProfile::valueChangedT2(double v)
362 // DD("valueChangedT2");
363 if (mRadioButtonLowerThan->isChecked()) {
364 mThresholdSlider1->SetMaximum(v);
365 if (!mInteractiveDisplayIsEnabled) return;
366 for(int i=0;i<mCurrentSlicerManager->GetNumberOfSlicers(); i++) {
367 mImageContourLower[i]->Update(v);
369 mCurrentSlicerManager->Render();
372 //------------------------------------------------------------------------------
375 //------------------------------------------------------------------------------
376 void vvToolProfile::valueChangedT1(double v)
378 // DD("valueChangedT1");
379 if (!mCurrentSlicerManager) close();
380 mThresholdSlider2->SetMinimum(v);
381 // int m1 = (int)lrint(v);
382 if (!mInteractiveDisplayIsEnabled) return;
383 for(int i=0;i<mCurrentSlicerManager->GetNumberOfSlicers(); i++) {
384 mImageContour[i]->Update(v);
386 mCurrentSlicerManager->Render();
388 //------------------------------------------------------------------------------