X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ModuleConnector.cpp;h=970cb045c6aad989e23ec9d9b9dbe54ace120437;hb=965adcb3288bda478cdd045d4b2f90c92980d099;hp=ce9ca36806ef450d1215e75cc810f00564de51e6;hpb=c1d68a49306543937c9c27de15b6e16de38e33d8;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ModuleConnector.cpp b/src/XGUI/XGUI_ModuleConnector.cpp index ce9ca3680..970cb045c 100644 --- a/src/XGUI/XGUI_ModuleConnector.cpp +++ b/src/XGUI/XGUI_ModuleConnector.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> + // File: XGUI_ModuleConnector.cpp // Created: 3 June 2014 // Author: Vitaly Smetannikov @@ -10,6 +12,9 @@ #include "XGUI_OperationMgr.h" #include "XGUI_Displayer.h" +#include + + XGUI_ModuleConnector::XGUI_ModuleConnector(XGUI_Workshop* theWorkshop) : ModuleBase_IWorkshop(theWorkshop), myWorkshop(theWorkshop) @@ -19,14 +24,12 @@ XGUI_ModuleConnector::XGUI_ModuleConnector(XGUI_Workshop* theWorkshop) XGUI_OperationMgr* anOperationMgr = myWorkshop->operationMgr(); - connect(anOperationMgr, SIGNAL(operationStarted(ModuleBase_Operation*)), - this, SIGNAL(operationStarted(ModuleBase_Operation*))); - connect(anOperationMgr, SIGNAL(operationStopped(ModuleBase_Operation*)), - this, SIGNAL(operationStopped(ModuleBase_Operation*))); + //myDocumentShapeFilter = new ModuleBase_ShapeDocumentFilter(this); } XGUI_ModuleConnector::~XGUI_ModuleConnector() { + //myDocumentShapeFilter.Nullify(); } ModuleBase_ISelection* XGUI_ModuleConnector::selection() const @@ -53,14 +56,46 @@ ModuleBase_Operation* XGUI_ModuleConnector::currentOperation() const void XGUI_ModuleConnector::activateSubShapesSelection(const QIntList& theTypes) { XGUI_Displayer* aDisp = myWorkshop->displayer(); - aDisp->openLocalContext(); - // Use empty list because we will use standard modes - aDisp->activateObjectsOutOfContext(QIntList()); - aDisp->setSelectionModes(theTypes); + // 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) { + 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); } void XGUI_ModuleConnector::deactivateSubShapesSelection() { XGUI_Displayer* aDisp = myWorkshop->displayer(); - aDisp->closeLocalContexts(false); + // The document limitation selection has to be only during operation + //aDisp->removeSelectionFilter(myDocumentShapeFilter); + //aDisp->closeLocalContexts(false); +} + +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 +{ + XGUI_Displayer* aDisp = myWorkshop->displayer(); + return aDisp->getObject(theAIS); +} + +void XGUI_ModuleConnector::setSelected(const QObjectPtrList& theFeatures) +{ + XGUI_Displayer* aDisp = myWorkshop->displayer(); + aDisp->setSelected(theFeatures); +} + +bool XGUI_ModuleConnector::canStartOperation(QString theId) +{ + return myWorkshop->operationMgr()->canStartOperation(theId); }