diff --git a/src/GEOMGUI/GEOM_msg_en.ts b/src/GEOMGUI/GEOM_msg_en.ts index 29fd2251d..5989610f8 100644 --- a/src/GEOMGUI/GEOM_msg_en.ts +++ b/src/GEOMGUI/GEOM_msg_en.ts @@ -6977,5 +6977,29 @@ Do you want to create new material? GEOM_CHECK_SELF_INTERSECTIONS_ERRORS Warning: there were errors during the operation, so the list may be incomplete. + + GEOM_CHECK_INTE_V_V + Vertex to Vertex + + + GEOM_CHECK_INTE_V_E + Vertex to Edge + all above + + + GEOM_CHECK_INTE_E_E + Edge to Edge + all above + + + GEOM_CHECK_INTE_V_F + Vertex to Face + all above + + + GEOM_CHECK_INTE_E_F + Edge to Face + all above + + + GEOM_CHECK_INTE_ALL + All interferences + diff --git a/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.cxx b/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.cxx index 10227dc04..de58de84c 100644 --- a/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.cxx +++ b/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.cxx @@ -131,7 +131,7 @@ MeasureGUI_CheckSelfIntersectionsDlg::MeasureGUI_CheckSelfIntersectionsDlg (Geom /***************************************************************/ - myHelpFileName = "using_measurement_tools_page.html#check_self_intersections_anchor"; + myHelpFileName = "check_self_intersections_page.html"; /* Initialisation */ Init(); @@ -151,6 +151,15 @@ MeasureGUI_CheckSelfIntersectionsDlg::~MeasureGUI_CheckSelfIntersectionsDlg() //================================================================================= void MeasureGUI_CheckSelfIntersectionsDlg::Init() { + // Fill in the combo box. + myLevelBox->insertItem(GEOM::SI_V_V, tr("GEOM_CHECK_INTE_V_V")); + myLevelBox->insertItem(GEOM::SI_V_E, tr("GEOM_CHECK_INTE_V_E")); + myLevelBox->insertItem(GEOM::SI_E_E, tr("GEOM_CHECK_INTE_E_E")); + myLevelBox->insertItem(GEOM::SI_V_F, tr("GEOM_CHECK_INTE_V_F")); + myLevelBox->insertItem(GEOM::SI_E_F, tr("GEOM_CHECK_INTE_E_F")); + myLevelBox->insertItem(GEOM::SI_ALL, tr("GEOM_CHECK_INTE_ALL")); + myLevelBox->setCurrentIndex(GEOM::SI_ALL); + connect(myGeomGUI, SIGNAL(SignalDeactivateActiveDialog()), this, SLOT(DeactivateActiveDialog())); connect(myGeomGUI, SIGNAL(SignalCloseAllDialogs()), @@ -163,6 +172,9 @@ void MeasureGUI_CheckSelfIntersectionsDlg::Init() SLOT(onInteListSelectionChanged())); connect(myShapeList, SIGNAL(itemSelectionChanged()), SLOT(onSubShapesListSelectionChanged())); + connect(myLevelBox, SIGNAL(currentIndexChanged(int)), + this, SLOT(clear())); + connect(myComputeButton, SIGNAL(clicked()), this, SLOT(onCompute())); LightApp_SelectionMgr* aSel = myGeomGUI->getApp()->selectionMgr(); @@ -178,7 +190,75 @@ void MeasureGUI_CheckSelfIntersectionsDlg::Init() } //================================================================================= -// function : ActivateThisDialog() +// function : clear +// purpose : +//================================================================================= +void MeasureGUI_CheckSelfIntersectionsDlg::clear() +{ + myTextView->setText(""); + disconnect(myInteList, SIGNAL(itemSelectionChanged()), this, 0); + disconnect(myShapeList, SIGNAL(itemSelectionChanged()), this, 0); + myInteList->clear(); + myShapeList->clear(); + connect(myInteList, SIGNAL(itemSelectionChanged()), + SLOT(onInteListSelectionChanged())); + connect(myShapeList, SIGNAL(itemSelectionChanged()), + SLOT(onSubShapesListSelectionChanged())); + erasePreview(); + buttonOk()->setEnabled(false); + buttonApply()->setEnabled(false); + myComputeButton->setEnabled(true); +} + +//================================================================================= +// function : onCompute +// purpose : +//================================================================================= +void MeasureGUI_CheckSelfIntersectionsDlg::onCompute() +{ + bool hasSelfInte = false; + QString anErrMsg(""); + + if (!findSelfIntersections(hasSelfInte, anErrMsg)) { + myTextView->setText(anErrMsg); + return; + } + + // Status and apply buttons + QString aMsg(""); + + if (hasSelfInte) { + aMsg += tr("GEOM_SELF_INTERSECTIONS_FOUND"); + buttonOk()->setEnabled(true); + buttonApply()->setEnabled(true); + } else { + aMsg += tr("GEOM_NO_SELF_INTERSECTIONS"); + } + + if (!anErrMsg.isEmpty()) { + aMsg += "\n\n"; + aMsg += anErrMsg; + } + + myTextView->setText(aMsg); + + // Pairs + QStringList anInteList; + QString anInteStr (""); + int nbPairs = myInters->length()/2; + + for (int i = 1; i <= nbPairs; i++) { + anInteStr = "Intersection # "; + anInteStr += QString::number(i); + anInteList.append(anInteStr); + } + + myInteList->addItems(anInteList); + myComputeButton->setEnabled(false); +} + +//================================================================================= +// function : ActivateThisDialog // purpose : //================================================================================= void MeasureGUI_CheckSelfIntersectionsDlg::ActivateThisDialog() @@ -235,7 +315,7 @@ bool MeasureGUI_CheckSelfIntersectionsDlg::ClickOnApply() } //================================================================================= -// function : SelectionIntoArgument +// function : extractPrefix // purpose : //================================================================================= bool MeasureGUI_CheckSelfIntersectionsDlg::extractPrefix() const @@ -277,6 +357,8 @@ void MeasureGUI_CheckSelfIntersectionsDlg::SetEditCurrentArgument() //================================================================================= void MeasureGUI_CheckSelfIntersectionsDlg::SelectionIntoArgument() { + // Clear the dialog. + clear(); myObj = GEOM::GEOM_Object::_nil(); LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr(); @@ -291,15 +373,11 @@ void MeasureGUI_CheckSelfIntersectionsDlg::SelectionIntoArgument() if (aSelectedObject->_is_nil()) { myEditObjName->setText(""); - processObject(); - erasePreview(); return; } myObj = aSelectedObject; myEditObjName->setText(GEOMBase::GetName(myObj)); - processObject(); - DISPLAY_PREVIEW_MACRO; } //================================================================================= @@ -327,9 +405,10 @@ bool MeasureGUI_CheckSelfIntersectionsDlg::findSelfIntersections GEOM::GEOM_IMeasureOperations::_narrow(getOperation()); bool isOK = true; int nbPairs = 0; + int aLevel = myLevelBox->currentIndex(); try { - HasSelfInte = !anOper->CheckSelfIntersections(myObj, GEOM::SI_ALL, myInters); + HasSelfInte = !anOper->CheckSelfIntersections(myObj, aLevel, myInters); nbPairs = myInters->length()/2; if (nbPairs*2 != myInters->length()) { @@ -356,64 +435,6 @@ bool MeasureGUI_CheckSelfIntersectionsDlg::findSelfIntersections return isOK; } -//================================================================================= -// function : processObject -// purpose : -//================================================================================= -void MeasureGUI_CheckSelfIntersectionsDlg::processObject() -{ - disconnect(myInteList, SIGNAL(itemSelectionChanged()), this, 0 ); - disconnect(myShapeList, SIGNAL(itemSelectionChanged()), this, 0 ); - myInteList->clear(); - myShapeList->clear(); - connect(myInteList, SIGNAL(itemSelectionChanged()), - SLOT(onInteListSelectionChanged())); - connect(myShapeList, SIGNAL(itemSelectionChanged()), - SLOT(onSubShapesListSelectionChanged())); - erasePreview(); - - bool hasSelfInte = false; - QString anErrMsg(""); - - if (!findSelfIntersections(hasSelfInte, anErrMsg)) { - myTextView->setText(anErrMsg); - return; - } - - // Status and apply buttons - QString aMsg(""); - - if (hasSelfInte) { - aMsg += tr("GEOM_SELF_INTERSECTIONS_FOUND"); - buttonOk()->setEnabled(true); - buttonApply()->setEnabled(true); - } else { - aMsg += tr("GEOM_NO_SELF_INTERSECTIONS"); - buttonOk()->setEnabled(false); - buttonApply()->setEnabled(false); - } - - if (!anErrMsg.isEmpty()) { - aMsg += "\n\n"; - aMsg += anErrMsg; - } - - myTextView->setText(aMsg); - - // Pairs - QStringList anInteList; - QString anInteStr (""); - int nbPairs = myInters->length()/2; - - for (int i = 1; i <= nbPairs; i++) { - anInteStr = "Intersection # "; - anInteStr += QString::number(i); - anInteList.append(anInteStr); - } - - myInteList->addItems(anInteList); -} - //================================================================================= // function : onInteListSelectionChanged // purpose : diff --git a/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.h b/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.h index 0e2681374..e9400be2d 100644 --- a/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.h +++ b/src/MeasureGUI/MeasureGUI_CheckSelfIntersectionsDlg.h @@ -55,12 +55,12 @@ protected: virtual bool extractPrefix() const; virtual GEOM::GEOM_Object_ptr getFather (GEOM::GEOM_Object_ptr); - void processObject(); - private slots: void onInteListSelectionChanged(); void onSubShapesListSelectionChanged(); + void clear(); + void onCompute(); void ClickOnOk(); bool ClickOnApply(); void ActivateThisDialog();