X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ModuleConnector.cpp;h=ee5f029d8445a4dd698c781be9e7555f00ae9bc0;hb=13d3f0d8b46a06931cbe8620b8563049eff4a9f6;hp=fdc407f7be5fa95b5a577b800f2748d43d346f16;hpb=f22a65689fa8bb54274a23f0f974fc538e4a22ab;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ModuleConnector.cpp b/src/XGUI/XGUI_ModuleConnector.cpp index fdc407f7b..ee5f029d8 100644 --- a/src/XGUI/XGUI_ModuleConnector.cpp +++ b/src/XGUI/XGUI_ModuleConnector.cpp @@ -13,6 +13,8 @@ #include "XGUI_Displayer.h" #include "XGUI_PropertyPanel.h" +#include + #include @@ -24,13 +26,10 @@ XGUI_ModuleConnector::XGUI_ModuleConnector(XGUI_Workshop* theWorkshop) connect(aSelector, SIGNAL(selectionChanged()), this, SIGNAL(selectionChanged())); XGUI_OperationMgr* anOperationMgr = myWorkshop->operationMgr(); - - //myDocumentShapeFilter = new ModuleBase_ShapeDocumentFilter(this); } XGUI_ModuleConnector::~XGUI_ModuleConnector() { - //myDocumentShapeFilter.Nullify(); } ModuleBase_ISelection* XGUI_ModuleConnector::selection() const @@ -59,34 +58,36 @@ ModuleBase_Operation* XGUI_ModuleConnector::currentOperation() const } +QObjectPtrList XGUI_ModuleConnector::activeObjects(const QObjectPtrList& theObjList) const +{ + QObjectPtrList aActiveOPbjects; + ModuleBase_IModule* aModule = myWorkshop->module(); + // Activate objects only which can be activated + foreach (ObjectPtr aObj, theObjList) { + if (aModule->canActivateSelection(aObj)) + aActiveOPbjects.append(aObj); + } + return aActiveOPbjects; +} + void XGUI_ModuleConnector::activateSubShapesSelection(const QIntList& theTypes) { XGUI_Displayer* aDisp = myWorkshop->displayer(); - // Close context if it was opened in order to clear stsndard selection modes - //aDisp->closeLocalContexts(false); - //aDisp->openLocalContext(); - // Convert shape types to selection types - QIntList aModes; - foreach(int aType, theTypes) { - if (aType > TopAbs_SHAPE) - aModes.append(aType); - else - aModes.append(AIS_Shape::SelectionMode((TopAbs_ShapeEnum)aType)); - } - aDisp->activateObjects(aModes); - //TODO: We have to open Local context because at neutral point filters don't work (bug 25340) - //aDisp->addSelectionFilter(myDocumentShapeFilter); + aDisp->activateObjects(theTypes, activeObjects(aDisp->displayedObjects())); } void XGUI_ModuleConnector::deactivateSubShapesSelection() { - XGUI_Displayer* aDisp = myWorkshop->displayer(); // Clear selection modes + activateModuleSelectionModes(); +} + +void XGUI_ModuleConnector::activateModuleSelectionModes() +{ + XGUI_Displayer* aDisp = myWorkshop->displayer(); QIntList aModes; - aDisp->activateObjects(aModes); - // The document limitation selection has to be only during operation - //aDisp->removeSelectionFilter(myDocumentShapeFilter); - //aDisp->closeLocalContexts(false); + module()->activeSelectionModes(aModes); + aDisp->activateObjects(aModes, activeObjects(aDisp->displayedObjects())); } AISObjectPtr XGUI_ModuleConnector::findPresentation(const ObjectPtr& theObject) const @@ -98,13 +99,18 @@ AISObjectPtr XGUI_ModuleConnector::findPresentation(const ObjectPtr& theObject) ObjectPtr XGUI_ModuleConnector::findPresentedObject(const AISObjectPtr& theAIS) const { XGUI_Displayer* aDisp = myWorkshop->displayer(); - return aDisp->getObject(theAIS); + ObjectPtr anObject = aDisp->getObject(theAIS); + return anObject; } -void XGUI_ModuleConnector::setSelected(const QObjectPtrList& theFeatures) +void XGUI_ModuleConnector::setSelected(const QList& theValues) { XGUI_Displayer* aDisp = myWorkshop->displayer(); - aDisp->setSelected(theFeatures); + if (theValues.isEmpty()) { + myWorkshop->selector()->clearSelection(); + } else { + aDisp->setSelected(theValues); + } } bool XGUI_ModuleConnector::canStartOperation(QString theId) @@ -112,3 +118,17 @@ bool XGUI_ModuleConnector::canStartOperation(QString theId) return myWorkshop->operationMgr()->canStartOperation(theId); } +ModuleBase_Operation* XGUI_ModuleConnector::findStartedOperation(const QString& theId) +{ + return myWorkshop->operationMgr()->findOperation(theId); +} + +bool XGUI_ModuleConnector::canStopOperation(ModuleBase_Operation* theOperation) +{ + return myWorkshop->operationMgr()->canStopOperation(theOperation); +} + +void XGUI_ModuleConnector::abortOperation(ModuleBase_Operation* theOperation) +{ + myWorkshop->operationMgr()->abortOperation(theOperation); +}