X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FNewGeom%2FNewGeom_Module.cpp;h=75f33a64f9a32f8bb840b259b24d1f4e52427f3b;hb=592b8a38b3c9e2a6a7d3d1d180b1f9b5406c4415;hp=df50886286daa97c9a0f2c9217c74d9c65008989;hpb=9f1d5e2c89ba45d2ba3d098ca8ea020bd3310488;p=modules%2Fshaper.git diff --git a/src/NewGeom/NewGeom_Module.cpp b/src/NewGeom/NewGeom_Module.cpp index df5088628..75f33a64f 100644 --- a/src/NewGeom/NewGeom_Module.cpp +++ b/src/NewGeom/NewGeom_Module.cpp @@ -16,6 +16,7 @@ #include #include #include +#include #include #include @@ -122,7 +123,9 @@ void NewGeom_Module::initialize(CAM_Application* theApp) myWorkshop->startApplication(); LightApp_Application* anApp = dynamic_cast(theApp); if (anApp) + { connect(anApp, SIGNAL(preferenceResetToDefaults()), this, SLOT(onDefaultPreferences())); + } } //****************************************************** @@ -170,9 +173,6 @@ bool NewGeom_Module::activateModule(SUIT_Study* theStudy) myWorkshop->objectBrowser()->rebuildDataTree(); myWorkshop->updateCommandStatus(); myIsOpened = false; - // the display all results is not necessary anymore, it was commented in XGUI_Workshop, - // so it should be commented here - //QTimer::singleShot(1000, myWorkshop, SLOT(displayAllResults())); } else myWorkshop->updateCommandStatus(); @@ -191,8 +191,11 @@ bool NewGeom_Module::activateModule(SUIT_Study* theStudy) aResMgr->setValue("Study", "store_positions", false); // Synchronize displayed objects - if (mySelector && mySelector->viewer()) { - Handle(AIS_InteractiveContext) aContext = mySelector->viewer()->getAISContext(); + Handle(AIS_InteractiveContext) aContext; + if (mySelector && mySelector->viewer()) + aContext = mySelector->viewer()->getAISContext(); + + if (!aContext.IsNull()) { XGUI_Displayer* aDisp = myWorkshop->displayer(); QObjectPtrList aObjList = aDisp->displayedObjects(); @@ -271,6 +274,8 @@ void NewGeom_Module::onViewManagerAdded(SUIT_ViewManager* theMgr) { if (!mySelector) { mySelector = createSelector(theMgr); + myWorkshop->module()->activateSelectionFilters(); + myWorkshop->synchronizeViewer(); } } @@ -289,6 +294,8 @@ void NewGeom_Module::onViewManagerRemoved(SUIT_ViewManager* theMgr) myProxyViewer->setSelector(0); delete mySelector; mySelector = 0; + + myWorkshop->module()->clearViewer(); } } } @@ -311,6 +318,8 @@ void NewGeom_Module::onDefaultPreferences() LightApp_Preferences* pref = preferences(); if (pref) pref->retrieve(); + + myWorkshop->displayer()->redisplayObjects(); } //****************************************************** @@ -398,14 +407,14 @@ QAction* NewGeom_Module::addFeature(const QString& theWBName, const QString& the return aAction; } -bool NewGeom_Module::isNestedFeature(const QAction* theAction) +bool NewGeom_Module::isFeatureOfNested(const QAction* theAction) { return dynamic_cast(theAction); } -QAction* NewGeom_Module::addNestedFeature(const QString& theWBName, - const ActionInfo& theInfo, - const QList& theNestedActions) +QAction* NewGeom_Module::addFeatureOfNested(const QString& theWBName, + const ActionInfo& theInfo, + const QList& theNestedActions) { int aMenu = createMenu(theWBName, -1, -1, 50); int aTool = createTool(theWBName, theWBName); @@ -605,6 +614,7 @@ void NewGeom_Module::preferencesChanged(const QString& theSection, const QString } aProp->setValue(aValue); + myWorkshop->displayer()->redisplayObjects(); } void NewGeom_Module::inspectSalomeModules() @@ -615,3 +625,8 @@ void NewGeom_Module::inspectSalomeModules() Config_ModuleReader::addDependencyModule(eachModule.toStdString()); } } + +bool NewGeom_Module::abortAllOperations() +{ + return workshop()->operationMgr()->abortAllOperations(); +}