X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ModuleConnector.cpp;h=5bb4445fe695490c00a5d2208e28fd17533224e6;hb=7778069b85fb13f2cd02c3cf5ad8ba6233b24e11;hp=a491a89ee3367e7f0010b81b426287d1839b5148;hpb=1a70f254f1fdee715756b7aa235fe6e6b6ab042b;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ModuleConnector.cpp b/src/XGUI/XGUI_ModuleConnector.cpp index a491a89ee..5bb4445fe 100644 --- a/src/XGUI/XGUI_ModuleConnector.cpp +++ b/src/XGUI/XGUI_ModuleConnector.cpp @@ -2,33 +2,90 @@ // Created: 3 June 2014 // Author: Vitaly Smetannikov - #include "XGUI_ModuleConnector.h" #include "XGUI_Workshop.h" #include "XGUI_ViewerProxy.h" #include "XGUI_SelectionMgr.h" +#include "XGUI_Selection.h" +#include "XGUI_OperationMgr.h" +#include "XGUI_Displayer.h" +#include -XGUI_ModuleConnector::XGUI_ModuleConnector(XGUI_Workshop* theWorkshop) -: ModuleBase_IWorkshop(theWorkshop), myWorkshop(theWorkshop) +XGUI_ModuleConnector::XGUI_ModuleConnector(XGUI_Workshop* theWorkshop) + : ModuleBase_IWorkshop(theWorkshop), + myWorkshop(theWorkshop) { XGUI_SelectionMgr* aSelector = myWorkshop->selector(); connect(aSelector, SIGNAL(selectionChanged()), this, SIGNAL(selectionChanged())); + + 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 +{ + return myWorkshop->selector()->selection(); } -Handle(AIS_InteractiveContext) XGUI_ModuleConnector::AISContext() const +ModuleBase_IModule* XGUI_ModuleConnector::module() const { - return myWorkshop->viewer()->AISContext(); + return myWorkshop->module(); } +ModuleBase_IViewer* XGUI_ModuleConnector::viewer() const +{ + return myWorkshop->viewer(); +} -QFeatureList XGUI_ModuleConnector::selectedFeatures() const +ModuleBase_Operation* XGUI_ModuleConnector::currentOperation() const { - return myWorkshop->selector()->selectedFeatures(); + return myWorkshop->operationMgr()->currentOperation(); } + +void XGUI_ModuleConnector::activateSubShapesSelection(const QIntList& theTypes) +{ + XGUI_Displayer* aDisp = myWorkshop->displayer(); + aDisp->openLocalContext(); + // Convert shape types to selection types + QIntList aModes; + foreach(int aType, theTypes) { + aModes.append(AIS_Shape::SelectionMode((TopAbs_ShapeEnum)aType)); + } + aDisp->activateObjectsOutOfContext(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(); + // 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); +} \ No newline at end of file