X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ModuleConnector.cpp;h=b83edb4c8d158e4233a4368875f232d6234ee576;hb=ed67f7abf2985c7225b7862c076257825a421993;hp=23ba4ead7a63aba7965164f64892be0867a57719;hpb=3874b57fe5aba25ff5aee2a07654fc23c1ee8eb0;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ModuleConnector.cpp b/src/XGUI/XGUI_ModuleConnector.cpp index 23ba4ead7..b83edb4c8 100644 --- a/src/XGUI/XGUI_ModuleConnector.cpp +++ b/src/XGUI/XGUI_ModuleConnector.cpp @@ -11,6 +11,9 @@ #include "XGUI_Selection.h" #include "XGUI_OperationMgr.h" #include "XGUI_Displayer.h" +#include "XGUI_PropertyPanel.h" + +#include #include @@ -24,17 +27,6 @@ XGUI_ModuleConnector::XGUI_ModuleConnector(XGUI_Workshop* theWorkshop) XGUI_OperationMgr* anOperationMgr = myWorkshop->operationMgr(); - connect(anOperationMgr, SIGNAL(operationStarted(ModuleBase_Operation*)), - SIGNAL(operationStarted(ModuleBase_Operation*))); - connect(anOperationMgr, SIGNAL(operationStopped(ModuleBase_Operation*)), - SIGNAL(operationStopped(ModuleBase_Operation*))); - connect(anOperationMgr, SIGNAL(operationResumed(ModuleBase_Operation*)), - SIGNAL(operationResumed(ModuleBase_Operation*))); - connect(anOperationMgr, SIGNAL(operationComitted(ModuleBase_Operation*)), - SIGNAL(operationComitted(ModuleBase_Operation*))); - connect(anOperationMgr, SIGNAL(operationAborted(ModuleBase_Operation*)), - SIGNAL(operationAborted(ModuleBase_Operation*))); - //myDocumentShapeFilter = new ModuleBase_ShapeDocumentFilter(this); } @@ -58,6 +50,11 @@ ModuleBase_IViewer* XGUI_ModuleConnector::viewer() const return myWorkshop->viewer(); } +ModuleBase_IPropertyPanel* XGUI_ModuleConnector::propertyPanel() const +{ + return myWorkshop->propertyPanel(); +} + ModuleBase_Operation* XGUI_ModuleConnector::currentOperation() const { return myWorkshop->operationMgr()->currentOperation(); @@ -68,12 +65,15 @@ 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(); + //aDisp->closeLocalContexts(false); + //aDisp->openLocalContext(); // Convert shape types to selection types QIntList aModes; foreach(int aType, theTypes) { - aModes.append(AIS_Shape::SelectionMode((TopAbs_ShapeEnum)aType)); + 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) @@ -83,9 +83,20 @@ void XGUI_ModuleConnector::activateSubShapesSelection(const QIntList& theTypes) void XGUI_ModuleConnector::deactivateSubShapesSelection() { XGUI_Displayer* aDisp = myWorkshop->displayer(); + // Clear selection modes + QIntList aModes; + // TODO: check on OCC6.9.0 + // the module current active modes should not be deactivated in order to save the objects selected + // the deactivate object in the mode of selection leads to the object is deselected in the viewer. + // But, in OCC6.8.0 this deselection does not happened automatically. It is necessary to call + // ClearOutdatedSelection, but this method has an error in the realization, which should be fixed in + // the OCC6.9.0 release. Moreother, it is possible that ClearOutdatedSelection will be called inside + // Deactivate method of AIS_InteractiveContext. In this case, we need not call it. + module()->activeSelectionModes(aModes); + aDisp->activateObjects(aModes); // The document limitation selection has to be only during operation //aDisp->removeSelectionFilter(myDocumentShapeFilter); - aDisp->closeLocalContexts(false); + //aDisp->closeLocalContexts(false); } AISObjectPtr XGUI_ModuleConnector::findPresentation(const ObjectPtr& theObject) const @@ -103,10 +114,15 @@ ObjectPtr XGUI_ModuleConnector::findPresentedObject(const AISObjectPtr& theAIS) void XGUI_ModuleConnector::setSelected(const QObjectPtrList& theFeatures) { XGUI_Displayer* aDisp = myWorkshop->displayer(); - aDisp->setSelected(theFeatures); + if (theFeatures.isEmpty()) { + myWorkshop->selector()->clearSelection(); + } else { + aDisp->setSelected(theFeatures); + } } bool XGUI_ModuleConnector::canStartOperation(QString theId) { return myWorkshop->operationMgr()->canStartOperation(theId); } +