SetToolMenuName("Extract lungs");
SetToolIconFilename(":/common/icons/lung-overlay.png");
SetToolTip("Extract lung mask from thorax CT.");
- // SetToolExperimental(true);
+ SetToolExperimental(true);
// SetToolInMenu("Segmentation");
}
//------------------------------------------------------------------------------
//------------------------------------------------------------------------------
void vvToolExtractLung::GetArgsInfoFromGUI()
{
- mArgsInfo->patientBG_arg = mPatientMaskInputWidget->GetBackgroundValue();
+ // mArgsInfo->patientBG_arg = mPatientMaskInputWidget->GetBackgroundValue();
mArgsInfo->verboseOption_flag = true; // DEBUG. TO CHANGE
mArgsInfo->verboseStep_flag = true; // DEBUG. TO CHANGE
mArgsInfo->writeStep_flag = false;
mArgsInfo->input_given = 0;
- mArgsInfo->patient_given = 0;
+ // mArgsInfo->patient_given = 0;
mArgsInfo->output_given = 0;
mArgsInfo->outputTrachea_given = 0;
- mArgsInfo->remove1_given = 0;
+ // mArgsInfo->remove1_given = 0;
mArgsInfo->upper_arg = mAirUpperThresholdSlider->GetValue();
mArgsInfo->lower_arg = mAirLowerThresholdSlider->GetValue();
// Create new filter
if (mFilter) delete mFilter;
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);
- thread.Update();
+ try {
+ thread.Update();
+ }
+ catch(std::runtime_error e) {
+ DD("Error exception handling");
+ DD(m_IsThreadInterrupted);
// Check if the thread has been canceled. In this case, return
if (m_IsThreadInterrupted) {
m_IsThreadInterrupted = false;
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;
- }
+ // }
+ } // end exception
// Get output
std::vector<vvImage::Pointer> output = mFilter->GetOutputVVImages();