X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_OperationMgr.cpp;h=5db1d07a7f8f405993ff2c7fca3df30d2eea37fc;hb=06e7f5859095193fc7f498bd89a7d28009794f53;hp=347a7e62fc7935b0067c9a752b2d7aa3755c8560;hpb=645e2cb70c0e40290725f28fdc5fec8a93338d28;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_OperationMgr.cpp b/src/XGUI/XGUI_OperationMgr.cpp index 347a7e62f..5db1d07a7 100644 --- a/src/XGUI/XGUI_OperationMgr.cpp +++ b/src/XGUI/XGUI_OperationMgr.cpp @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2019 CEA/DEN, EDF R&D +// Copyright (C) 2014-2023 CEA, EDF // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -29,6 +29,8 @@ #include "XGUI_Tools.h" #include "XGUI_ObjectsBrowser.h" #include "XGUI_ContextMenuMgr.h" +#include "XGUI_Selection.h" +#include "XGUI_SelectionMgr.h" #include #include @@ -52,6 +54,7 @@ #include #include #include +#include //#define DEBUG_CURRENT_FEATURE @@ -64,8 +67,8 @@ public: /// Constructor /// \param theParent the parent to be deleted when the parent is deleted /// \param theOperationMgr the class to perform deletion - XGUI_ShortCutListener(QObject* theParent, XGUI_OperationMgr* theOperationMgr) - : QObject(theParent), myOperationMgr(theOperationMgr), myIsActive(false) + XGUI_ShortCutListener(XGUI_OperationMgr* theOperationMgr) + : QObject(theOperationMgr), myOperationMgr(theOperationMgr), myIsActive(false) { qApp->installEventFilter(this); } @@ -75,48 +78,76 @@ public: void setActive(const bool theIsActive) { myIsActive = theIsActive; } /// Redefinition of virtual function to process Delete key release - virtual bool eventFilter(QObject *theObject, QEvent *theEvent) - { - bool isAccepted = false; - if (myIsActive) { + virtual bool eventFilter(QObject *theObject, QEvent *theEvent); + +private: + XGUI_OperationMgr* myOperationMgr; /// processor for key event + bool myIsActive; /// boolean state whether the event filter perform own signal processing +}; + +bool XGUI_ShortCutListener::eventFilter(QObject *theObject, QEvent *theEvent) +{ + bool isAccepted = false; + + if (myIsActive) { + // Do not process keys for modal dialogues: all keys has to be processed within the dialog + // There is only one exception: ModuleBase_EditorDialog + QWindow* aWnd = qApp->modalWindow(); + QString aName = "NoModal"; + if (aWnd) { + if (!aWnd->objectName().startsWith("ModuleBase_EditorDialog")) + aName = aWnd->objectName(); + } + if (aName == "NoModal") { if (theEvent->type() == QEvent::KeyRelease) { QKeyEvent* aKeyEvent = dynamic_cast(theEvent); if (aKeyEvent) { myOperationMgr->setSHIFTPressed(aKeyEvent->modifiers() & Qt::ShiftModifier); switch (aKeyEvent->key()) { - case Qt::Key_Delete: - isAccepted = myOperationMgr->onProcessDelete(theObject); + case Qt::Key_Delete: + isAccepted = myOperationMgr->onProcessDelete(theObject); + break; + case Qt::Key_F2: + { + QObjectPtrList anObjects = myOperationMgr->xworkshop()->selector()->selection()->selectedObjects(); + if (myOperationMgr->xworkshop()->abortAllOperations()) + { + myOperationMgr->xworkshop()->objectBrowser()->setObjectsSelected(anObjects); + myOperationMgr->xworkshop()->objectBrowser()->onEditItem(); + } + isAccepted = true; + break; + } + default: + isAccepted = myOperationMgr->onKeyReleased(theObject, aKeyEvent); break; - default: - isAccepted = myOperationMgr->onKeyReleased(theObject, aKeyEvent); - break; } } } else if (theEvent->type() == QEvent::KeyPress) { - QKeyEvent* aKeyEvent = dynamic_cast(theEvent); - myOperationMgr->setSHIFTPressed(aKeyEvent->modifiers() & Qt::ShiftModifier); - isAccepted = myOperationMgr->onKeyPressed(theObject, aKeyEvent); + if (myOperationMgr->hasOperation()) { + QKeyEvent* aKeyEvent = dynamic_cast(theEvent); + myOperationMgr->setSHIFTPressed(aKeyEvent->modifiers() & Qt::ShiftModifier); + isAccepted = myOperationMgr->onKeyPressed(theObject, aKeyEvent); + } } } - if (!isAccepted) - isAccepted = QObject::eventFilter(theObject, theEvent); - return isAccepted; } + if (!isAccepted) + isAccepted = QObject::eventFilter(theObject, theEvent); + return isAccepted; +} + -private: - XGUI_OperationMgr* myOperationMgr; /// processor for key event - bool myIsActive; /// boolean state whether the event filter perform own signal processing -}; XGUI_OperationMgr::XGUI_OperationMgr(QObject* theParent, - ModuleBase_IWorkshop* theWorkshop) -: QObject(theParent), myWorkshop(theWorkshop), mySHIFTPressed(false), myActiveMessageBox(0) + ModuleBase_IWorkshop* theWorkshop) +: QObject(theParent), myWorkshop(theWorkshop), myActiveMessageBox(0), mySHIFTPressed(false) { /// we need to install filter to the application in order to react to 'Delete' key button /// this key can not be a short cut for a corresponded action because we need to set /// the actions priority - myShortCutListener = new XGUI_ShortCutListener(theParent, this); + myShortCutListener = new XGUI_ShortCutListener(this); } XGUI_OperationMgr::~XGUI_OperationMgr() @@ -340,7 +371,7 @@ bool XGUI_OperationMgr::canStopOperation(ModuleBase_Operation* theOperation, if (theOperation && theOperation->isModified()) { ModuleBase_OperationFeature* aOp = dynamic_cast(theOperation); std::string aContext; - if (aOp) + if (aOp && aOp->feature()) aContext = aOp->feature()->getKind(); QString aTitle = Config_Translator::translate(aContext, theOperation->getDescription()->description().toStdString()).c_str(); @@ -374,7 +405,6 @@ bool XGUI_OperationMgr::isGrantedOperation(const QString& theId) QListIterator anIt(myOperations); anIt.toBack(); - ModuleBase_Operation* aPreviousOperation = 0; while (anIt.hasPrevious() && !isGranted) { ModuleBase_Operation* anOp = anIt.previous(); if (anOp) @@ -446,16 +476,16 @@ void XGUI_OperationMgr::stopOperation(ModuleBase_Operation* theOperation, bool& void XGUI_OperationMgr::abortOperation(ModuleBase_Operation* theOperation) { ModuleBase_Operation* aCurrentOperation = currentOperation(); - if (theOperation == aCurrentOperation) + if (theOperation && (theOperation == aCurrentOperation)) theOperation->abort(); else { // it is possible to trigger upper operation(e.g. sketch, current is sketch line) // all operation from the current to triggered should also be aborted // operations over the parameter one are not aborted(e.g. extrusion cut, sketch abort) while(hasOperation()) { - ModuleBase_Operation* aCurrentOperation = currentOperation(); - aCurrentOperation->abort(); - if(theOperation == aCurrentOperation) + ModuleBase_Operation* aCurOperation = currentOperation(); + aCurOperation->abort(); + if(theOperation == aCurOperation) break; } } @@ -709,7 +739,6 @@ bool XGUI_OperationMgr::onKeyReleased(QObject *theObject, QKeyEvent* theEvent) bool XGUI_OperationMgr::onKeyPressed(QObject *theObject, QKeyEvent* theEvent) { // Let the manager decide what to do with the given key combination. - ModuleBase_Operation* anOperation = currentOperation(); bool isAccepted = false; switch (theEvent->key()) { case Qt::Key_Escape: { @@ -723,15 +752,17 @@ bool XGUI_OperationMgr::onKeyPressed(QObject *theObject, QKeyEvent* theEvent) ModuleBase_Operation* aOperation = currentOperation(); if (!isAccepted && aOperation) { ModuleBase_IPropertyPanel* aPanel = aOperation->propertyPanel(); - ModuleBase_ModelWidget* anActiveWgt = aPanel->activeWidget(); - if (anActiveWgt) - { - isAccepted = anActiveWgt && anActiveWgt->processAction(ActionEscape); - if (isAccepted) { - ModuleBase_OperationFeature* aFOperation = - dynamic_cast(currentOperation()); - if (aFOperation) - aFOperation->setNeedToBeAborted(true); + if (aPanel) { + ModuleBase_ModelWidget* anActiveWgt = aPanel->activeWidget(); + if (anActiveWgt) + { + isAccepted = anActiveWgt && anActiveWgt->processAction(ActionEscape); + if (isAccepted) { + ModuleBase_OperationFeature* aFOperation = + dynamic_cast(currentOperation()); + if (aFOperation) + aFOperation->setNeedToBeAborted(true); + } } } } @@ -851,7 +882,7 @@ bool XGUI_OperationMgr::onProcessDelete(QObject* theObject) /// processing delete by workshop XGUI_ObjectsBrowser* aBrowser = XGUI_Tools::workshop(myWorkshop)->objectBrowser(); QWidget* aViewPort = myWorkshop->viewer()->activeViewPort(); - bool isToDeleteObject = true; + bool isToDeleteObject = false; XGUI_Workshop* aWorkshop = XGUI_Tools::workshop(myWorkshop); XGUI_ContextMenuMgr* aContextMenuMgr = aWorkshop->contextMenuMgr(); if (theObject == aBrowser->treeView()) { @@ -916,3 +947,9 @@ QMessageBox* XGUI_OperationMgr::createInformationBox(const QString& theMessage) return aMessageBox; } + +XGUI_Workshop* XGUI_OperationMgr::xworkshop() const +{ + XGUI_ModuleConnector* aConnector = (XGUI_ModuleConnector*) myWorkshop; + return aConnector->workshop(); +}