Authors belong to:
- University of LYON http://www.universite-lyon.fr/
- - Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
+ - Léon Bérard cancer center http://www.centreleonberard.fr
- CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr
This software is distributed WITHOUT ANY WARRANTY; without even
- BSD See included LICENSE.txt file
- CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
- ======================================================================-====*/
+ ===========================================================================**/
// vv
#include "vvToolExtractPatient.h"
SetToolMenuName("Extract Patient");
SetToolIconFilename(":/common/icons/Patient-overlay.png");
SetToolTip("Extract Patient mask from thorax CT.");
- // SetToolExperimental(true);
+ SetToolExperimental(true);
// SetToolInMenu("Segmentation");
}
//------------------------------------------------------------------------------
//if (mFilter) delete mFilter;
DD("new filter");
mFilter = new FilterType; // needed when thread cancel the filter
- mFilter->StopOnErrorOff();
+ // mFilter->StopOnErrorOff();
// mFilter->SetIOVerbose(true);
mFilter->AddInputVVImage(mCurrentImage); // CT
// mFilter->AddInputVVImage(mPatient); // patient mask
vvThreadedFilter thread;
connect(&thread, SIGNAL(ThreadInterrupted()), this, SLOT(ThreadInterrupted()));
thread.SetFilter(mFilter);
+
+ try {
thread.Update();
+ }
+ catch(std::runtime_error e) {
// Check if the thread has been canceled. In this case, return
if (m_IsThreadInterrupted) {
disconnect(&thread, SIGNAL(ThreadInterrupted()), this, SLOT(ThreadInterrupted()));
// Check error during filter
- if (mFilter->HasError()) {
+ // if (mFilter->HasError()) {
QApplication::restoreOverrideCursor();
- QMessageBox::information(this,tr("Error"), mFilter->GetLastError().c_str());
+ QMessageBox::information(this,tr("Error"), e.what());//mFilter->GetLastError().c_str());
return;
+ // }
+
}
// Get output