X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ModuleConnector.cpp;h=0c7dcd6beba771096d0057cad314e8df2af0a0c4;hb=d4b0a5cb916f4eccf4a0bce02e43a54c7a67cb93;hp=b832fbb3071833f34b1eb610a7dcef366587b1c3;hpb=1c530eba1d76c012cfc61df1c21694e62f203d94;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ModuleConnector.cpp b/src/XGUI/XGUI_ModuleConnector.cpp index b832fbb30..0c7dcd6be 100644 --- a/src/XGUI/XGUI_ModuleConnector.cpp +++ b/src/XGUI/XGUI_ModuleConnector.cpp @@ -21,13 +21,15 @@ #include "XGUI_ModuleConnector.h" #include "XGUI_Workshop.h" #include "XGUI_ViewerProxy.h" -#include "XGUI_SelectionMgr.h" #include "XGUI_Selection.h" +#include "XGUI_SelectionActivate.h" +#include "XGUI_SelectionMgr.h" #include "XGUI_OperationMgr.h" #include "XGUI_Displayer.h" #include "XGUI_PropertyPanel.h" #include "XGUI_ActionsMgr.h" #include "XGUI_ErrorMgr.h" +#include "XGUI_ObjectsBrowser.h" #include #include @@ -78,6 +80,11 @@ ModuleBase_IErrorMgr* XGUI_ModuleConnector::errorMgr() const return myWorkshop->errorMgr(); } +ModuleBase_ISelectionActivate* XGUI_ModuleConnector::selectionActivate() const +{ + return myWorkshop->selectionActivate(); +} + ModuleBase_Operation* XGUI_ModuleConnector::currentOperation() const { return myWorkshop->operationMgr()->currentOperation(); @@ -96,32 +103,18 @@ QObjectPtrList XGUI_ModuleConnector::activeObjects(const QObjectPtrList& theObjL return aActiveOPbjects; } -void XGUI_ModuleConnector::activateSubShapesSelection(const QIntList& theTypes) +AISObjectPtr XGUI_ModuleConnector::findPresentation(const ObjectPtr& theObject) const { - QIntList aTypes = theTypes; - XGUI_Displayer* aDisp = myWorkshop->displayer(); - myWorkshop->module()->customSubShapesSelectionModes(aTypes); - aDisp->activateObjects(aTypes, activeObjects(aDisp->displayedObjects())); -} - -void XGUI_ModuleConnector::deactivateSubShapesSelection() -{ - // Clear selection modes - activateModuleSelectionModes(); + return aDisp->getAISObject(theObject); } -void XGUI_ModuleConnector::activateModuleSelectionModes() +bool XGUI_ModuleConnector::isVisible(const ObjectPtr& theObject) const { XGUI_Displayer* aDisp = myWorkshop->displayer(); - myWorkshop->activateObjectsSelection(activeObjects(aDisp->displayedObjects())); + return aDisp->isVisible(theObject); } -AISObjectPtr XGUI_ModuleConnector::findPresentation(const ObjectPtr& theObject) const -{ - XGUI_Displayer* aDisp = myWorkshop->displayer(); - return aDisp->getAISObject(theObject); -} ObjectPtr XGUI_ModuleConnector::findPresentedObject(const AISObjectPtr& theAIS) const { @@ -133,10 +126,19 @@ ObjectPtr XGUI_ModuleConnector::findPresentedObject(const AISObjectPtr& theAIS) void XGUI_ModuleConnector::setSelected(const QList& theValues) { XGUI_Displayer* aDisp = myWorkshop->displayer(); + XGUI_ObjectsBrowser* aBrowser = myWorkshop->objectBrowser(); if (theValues.isEmpty()) { myWorkshop->selector()->clearSelection(); - } else + aBrowser->treeView()->clearSelection(); + } else { aDisp->setSelected(theValues); + // Synchronise the selection with Object browser + QObjectPtrList anObjects; + foreach(ModuleBase_ViewerPrsPtr aVal, theValues) { + anObjects.append(aVal->object()); + } + aBrowser->setObjectsSelected(anObjects); + } } void XGUI_ModuleConnector::setStatusBarMessage(const QString& theMessage)