X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ContextMenuMgr.cpp;h=8557a43f972489ffbb5c490282131b11e69f11b6;hb=8f09d362a50ccbc085841c24af2e755121e458ba;hp=80fdfad7f07ece1ba1b23243e578fdf41ad8d9e6;hpb=114994217c1f77cdc9ab17984456c46808812325;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ContextMenuMgr.cpp b/src/XGUI/XGUI_ContextMenuMgr.cpp index 80fdfad7f..8557a43f9 100644 --- a/src/XGUI/XGUI_ContextMenuMgr.cpp +++ b/src/XGUI/XGUI_ContextMenuMgr.cpp @@ -16,21 +16,25 @@ #include #include #include -#include #include #include #include +#include +#include #include +#include #include #include #include #include + XGUI_ContextMenuMgr::XGUI_ContextMenuMgr(XGUI_Workshop* theParent) : QObject(theParent), - myWorkshop(theParent) + myWorkshop(theParent), + mySeparator(0) { } @@ -40,16 +44,7 @@ XGUI_ContextMenuMgr::~XGUI_ContextMenuMgr() void XGUI_ContextMenuMgr::createActions() { - QAction* aAction = new QAction(QIcon(":pictures/edit.png"), tr("Edit..."), this); - addAction("EDIT_CMD", aAction); - - aAction = new QAction(QIcon(":pictures/activate.png"), tr("Activate"), this); - addAction("ACTIVATE_PART_CMD", aAction); - - aAction = new QAction(QIcon(":pictures/assembly.png"), tr("Deactivate"), this); - addAction("DEACTIVATE_PART_CMD", aAction); - - aAction = new QAction(QIcon(":pictures/delete.png"), tr("Delete"), this); + QAction* aAction = new QAction(QIcon(":pictures/delete.png"), tr("Delete"), this); QMainWindow* aDesktop = myWorkshop->mainWindow(); if (!aDesktop) aDesktop = myWorkshop->salomeConnector()->desktop(); @@ -59,7 +54,14 @@ void XGUI_ContextMenuMgr::createActions() aAction->setShortcut(Qt::Key_Delete); aAction->setShortcutContext(Qt::ApplicationShortcut); - aAction = new QAction(QIcon(":pictures/color.png"), tr("Color"), this); + aAction = new QAction(QIcon(":pictures/rename_edit.png"), tr("Rename"), this); + addAction("RENAME_CMD", aAction); + connect(aAction, SIGNAL(triggered(bool)), this, SLOT(onRename())); + + aAction = new QAction(QIcon(":pictures/move.png"), tr("Move..."), this); + addAction("MOVE_CMD", aAction); + + aAction = new QAction(QIcon(":pictures/color.png"), tr("Color..."), this); addAction("COLOR_CMD", aAction); aAction = new QAction(QIcon(":pictures/eye_pencil.png"), tr("Show"), this); @@ -79,6 +81,13 @@ void XGUI_ContextMenuMgr::createActions() aAction = new QAction(QIcon(":pictures/wireframe.png"), tr("Wireframe"), this); addAction("WIREFRAME_CMD", aAction); + + mySeparator = new QAction(this); + mySeparator->setSeparator(true); + + + buildObjBrowserMenu(); + buildViewerMenu(); } void XGUI_ContextMenuMgr::addAction(const QString& theId, QAction* theAction) @@ -124,11 +133,13 @@ void XGUI_ContextMenuMgr::updateCommandsStatus() void XGUI_ContextMenuMgr::onContextMenuRequest(QContextMenuEvent* theEvent) { - QMenu* aMenu = 0; - if (sender() == myWorkshop->objectBrowser()) - aMenu = objectBrowserMenu(); - else if (sender() == myWorkshop->viewer()) { - aMenu = viewerMenu(); + QMenu* aMenu = new QMenu(); + if (sender() == myWorkshop->objectBrowser()) { + updateObjectBrowserMenu(); + addObjBrowserMenu(aMenu); + } else if (sender() == myWorkshop->viewer()) { + updateViewerMenu(); + addViewerMenu(aMenu); } if (aMenu && (aMenu->actions().size() > 0)) { @@ -142,9 +153,11 @@ void XGUI_ContextMenuMgr::onContextMenuRequest(QContextMenuEvent* theEvent) } } -QMenu* XGUI_ContextMenuMgr::objectBrowserMenu() const +void XGUI_ContextMenuMgr::updateObjectBrowserMenu() { - QMenu* aMenu = new QMenu(); + foreach(QAction* aAction, myActions) + aAction->setEnabled(false); + XGUI_SelectionMgr* aSelMgr = myWorkshop->selector(); QObjectPtrList aObjects = aSelMgr->selection()->selectedObjects(); int aSelected = aObjects.size(); @@ -154,138 +167,254 @@ QMenu* XGUI_ContextMenuMgr::objectBrowserMenu() const bool hasResult = false; bool hasFeature = false; bool hasParameter = false; - foreach(ObjectPtr aObj, aObjects) - { - FeaturePtr aFeature = std::dynamic_pointer_cast(aObj); - ResultPtr aResult = std::dynamic_pointer_cast(aObj); - ResultParameterPtr aConstruction = std::dynamic_pointer_cast(aResult); - - hasResult = (aResult.get() != NULL); - hasFeature = (aFeature.get() != NULL); - hasParameter = (aConstruction.get() != NULL); - if (hasFeature && hasResult && hasParameter) - break; - } + bool hasSubFeature = false; + ModuleBase_Tools::checkObjects(aObjects, hasResult, hasFeature, hasParameter, hasSubFeature); + //Process Feature if (aSelected == 1) { ObjectPtr aObject = aObjects.first(); if (aObject) { - ResultPartPtr aPart = std::dynamic_pointer_cast(aObject); - if (aPart) { - if (aMgr->activeDocument() == aPart->partDoc()) - aMenu->addAction(action("DEACTIVATE_PART_CMD")); - else - aMenu->addAction(action("ACTIVATE_PART_CMD")); - } else if (hasFeature && aObject->document() == aMgr->activeDocument()) { - aMenu->addAction(action("EDIT_CMD")); - } else { - if (aDisplayer->isVisible(aObject)) { + if (!hasFeature) { + if (aObject->isDisplayed()) { if (aDisplayer->canBeShaded(aObject)) { - if (aDisplayer->displayMode(aObject) == XGUI_Displayer::Shading) - aMenu->addAction(action("WIREFRAME_CMD")); - else - aMenu->addAction(action("SHADING_CMD")); + action("WIREFRAME_CMD")->setEnabled(true); + action("SHADING_CMD")->setEnabled(true); } - aMenu->addSeparator(); - aMenu->addAction(action("HIDE_CMD")); - } else if (!hasParameter) { - aMenu->addAction(action("SHOW_CMD")); + action("HIDE_CMD")->setEnabled(true); + } else if (hasResult && (!hasParameter)) { + action("SHOW_CMD")->setEnabled(true); } - if (hasParameter) - aMenu->addAction(action("EDIT_CMD")); - else - aMenu->addAction(action("SHOW_ONLY_CMD")); + + if (!(hasParameter || hasFeature)) + action("SHOW_ONLY_CMD")->setEnabled(true); + } + else if (hasFeature && myWorkshop->canMoveFeature()) + action("MOVE_CMD")->setEnabled(true); + + if( aMgr->activeDocument() == aObject->document() ) + { + action("RENAME_CMD")->setEnabled(true); + action("DELETE_CMD")->setEnabled(true); } - } else { // If feature is 0 the it means that selected root object (document) - if (aMgr->activeDocument() != aMgr->moduleDocument()) - aMenu->addAction(action("ACTIVATE_PART_CMD")); } } else { if (hasResult && (!hasParameter)) { - aMenu->addAction(action("SHOW_CMD")); - aMenu->addAction(action("HIDE_CMD")); - aMenu->addAction(action("SHOW_ONLY_CMD")); - aMenu->addSeparator(); - aMenu->addAction(action("SHADING_CMD")); - aMenu->addAction(action("WIREFRAME_CMD")); + action("SHOW_CMD")->setEnabled(true); + action("HIDE_CMD")->setEnabled(true); + action("SHOW_ONLY_CMD")->setEnabled(true); + action("SHADING_CMD")->setEnabled(true); + action("WIREFRAME_CMD")->setEnabled(true); + } + } + bool allActive = true; + foreach( ObjectPtr aObject, aObjects ) + if( aMgr->activeDocument() != aObject->document() ) + { + allActive = false; + break; } + if (!hasSubFeature && allActive ) { + if (hasFeature || hasParameter) + action("DELETE_CMD")->setEnabled(true); } - if (hasFeature || hasParameter) - aMenu->addAction(action("DELETE_CMD")); } if (myWorkshop->canChangeColor()) - aMenu->addAction(action("COLOR_CMD")); - - aMenu->addSeparator(); - aMenu->addActions(myWorkshop->objectBrowser()->actions()); + action("COLOR_CMD")->setEnabled(true); ModuleBase_IModule* aModule = myWorkshop->module(); if (aModule) - aModule->addObjectBrowserItems(aMenu); + aModule->updateObjectBrowserMenu(myActions); +} + +void XGUI_ContextMenuMgr::updateViewerMenu() +{ + foreach(QAction* aAction, myActions) + aAction->setEnabled(false); - if (aMenu->actions().size() > 0) { - return aMenu; + XGUI_SelectionMgr* aSelMgr = myWorkshop->selector(); + QList aPrsList = aSelMgr->selection()->getSelected(ModuleBase_ISelection::Viewer); + if (aPrsList.size() > 0) { + bool isVisible = false; + bool isShading = false; + bool canBeShaded = false; + ObjectPtr aObject; + foreach(ModuleBase_ViewerPrs aPrs, aPrsList) { + aObject = aPrs.object(); + ResultPtr aRes = std::dynamic_pointer_cast(aObject); + if (aRes && aRes->isDisplayed()) { + isVisible = true; + canBeShaded = myWorkshop->displayer()->canBeShaded(aObject); + isShading = (myWorkshop->displayer()->displayMode(aObject) == XGUI_Displayer::Shading); + break; + } + } + if (isVisible) { + if (canBeShaded) { + action("WIREFRAME_CMD")->setEnabled(true); + action("SHADING_CMD")->setEnabled(true); + } + action("SHOW_ONLY_CMD")->setEnabled(true); + action("HIDE_CMD")->setEnabled(true); + } else + action("SHOW_CMD")->setEnabled(true); } - delete aMenu; - return 0; + if (myWorkshop->displayer()->objectsCount() > 0) + action("HIDEALL_CMD")->setEnabled(true); + if (myWorkshop->canChangeColor()) + action("COLOR_CMD")->setEnabled(true); + + action("DELETE_CMD")->setEnabled(true); + + ModuleBase_IModule* aModule = myWorkshop->module(); + if (aModule) + aModule->updateViewerMenu(myActions); } -QMenu* XGUI_ContextMenuMgr::viewerMenu() const +void XGUI_ContextMenuMgr::connectObjectBrowser() { - QMenu* aMenu = new QMenu(); - addViewerItems(aMenu); - if (aMenu->actions().size() > 0) { - return aMenu; + connect(myWorkshop->objectBrowser(), SIGNAL(contextMenuRequested(QContextMenuEvent*)), this, + SLOT(onContextMenuRequest(QContextMenuEvent*))); +} + +void XGUI_ContextMenuMgr::connectViewer() +{ + connect(myWorkshop->viewer(), SIGNAL(contextMenuRequested(QContextMenuEvent*)), this, + SLOT(onContextMenuRequest(QContextMenuEvent*))); +} + + +void XGUI_ContextMenuMgr::buildObjBrowserMenu() +{ + QAction* aSeparator = new QAction(this); + aSeparator->setSeparator(true); + + QActionsList aList; + + // Result construction menu + aList.append(action("SHOW_CMD")); + aList.append(action("HIDE_CMD")); + aList.append(action("SHOW_ONLY_CMD")); + aList.append(action("COLOR_CMD")); + aList.append(mySeparator); + aList.append(action("RENAME_CMD")); + myObjBrowserMenus[ModelAPI_ResultConstruction::group()] = aList; + //------------------------------------- + // Result body menu + aList.clear(); + aList.append(action("WIREFRAME_CMD")); + aList.append(action("SHADING_CMD")); + aList.append(action("COLOR_CMD")); + aList.append(mySeparator); + aList.append(action("SHOW_CMD")); + aList.append(action("HIDE_CMD")); + aList.append(action("SHOW_ONLY_CMD")); + aList.append(mySeparator); + aList.append(action("RENAME_CMD")); + myObjBrowserMenus[ModelAPI_ResultBody::group()] = aList; + // Group menu + myObjBrowserMenus[ModelAPI_ResultGroup::group()] = aList; + // Result part menu + myObjBrowserMenus[ModelAPI_ResultPart::group()] = aList; + //------------------------------------- + // Feature menu + aList.clear(); + aList.append(action("DELETE_CMD")); + aList.append(action("MOVE_CMD")); + aList.append(mySeparator); + aList.append(action("RENAME_CMD")); + myObjBrowserMenus[ModelAPI_Feature::group()] = aList; + + aList.clear(); + aList.append(action("DELETE_CMD")); + aList.append(mySeparator); + aList.append(action("RENAME_CMD")); + myObjBrowserMenus[ModelAPI_ResultParameter::group()] = aList; + //------------------------------------- +} + +void XGUI_ContextMenuMgr::buildViewerMenu() +{ + QActionsList aList; + // Result construction menu + aList.append(action("HIDE_CMD")); + aList.append(action("SHOW_ONLY_CMD")); + aList.append(action("HIDEALL_CMD")); + aList.append(action("COLOR_CMD")); + myViewerMenu[ModelAPI_ResultConstruction::group()] = aList; + // Result part menu + myViewerMenu[ModelAPI_ResultPart::group()] = aList; + //------------------------------------- + // Result body menu + aList.clear(); + aList.append(action("WIREFRAME_CMD")); + aList.append(action("SHADING_CMD")); + aList.append(action("COLOR_CMD")); + aList.append(mySeparator); + aList.append(action("HIDE_CMD")); + aList.append(action("SHOW_ONLY_CMD")); + aList.append(action("HIDEALL_CMD")); + myViewerMenu[ModelAPI_ResultBody::group()] = aList; + // Group menu + myViewerMenu[ModelAPI_ResultGroup::group()] = aList; + //------------------------------------- + +} + + +void XGUI_ContextMenuMgr::addObjBrowserMenu(QMenu* theMenu) const +{ + XGUI_SelectionMgr* aSelMgr = myWorkshop->selector(); + QObjectPtrList aObjects = aSelMgr->selection()->selectedObjects(); + int aSelected = aObjects.size(); + QActionsList aActions; + if (aSelected == 1) { + ObjectPtr aObject = aObjects.first(); + std::string aName = aObject->groupName(); + if (myObjBrowserMenus.contains(aName)) + aActions = myObjBrowserMenus[aName]; + } else if (aSelected > 1) { + aActions.append(action("SHADING_CMD")); + aActions.append(action("WIREFRAME_CMD")); + aActions.append(mySeparator); + aActions.append(action("SHOW_CMD")); + aActions.append(action("HIDE_CMD")); + aActions.append(action("SHOW_ONLY_CMD")); + aActions.append(mySeparator); + aActions.append(action("DELETE_CMD")); + //aActions.append(action("MOVE_CMD")); } - delete aMenu; - return 0; + theMenu->addActions(aActions); + + ModuleBase_IModule* aModule = myWorkshop->module(); + if (aModule) { + theMenu->addSeparator(); + aModule->addObjectBrowserMenu(theMenu); + } + theMenu->addSeparator(); + theMenu->addActions(myWorkshop->objectBrowser()->actions()); } -void XGUI_ContextMenuMgr::addViewerItems(QMenu* theMenu) const +void XGUI_ContextMenuMgr::addViewerMenu(QMenu* theMenu) const { - bool aIsDone = false; ModuleBase_IModule* aModule = myWorkshop->module(); - if (aModule) - aIsDone = aModule->addViewerItems(theMenu, myActions); - - if (!aIsDone) { - XGUI_SelectionMgr* aSelMgr = myWorkshop->selector(); - QObjectPtrList aObjects = aSelMgr->selection()->selectedObjects(); - if (aObjects.size() > 0) { - //if (aObjects.size() == 1) - // theMenu->addAction(action("EDIT_CMD")); - bool isVisible = false; - bool isShading = false; - bool canBeShaded = false; - foreach(ObjectPtr aObject, aObjects) - { - ResultPtr aRes = std::dynamic_pointer_cast(aObject); - if (aRes && myWorkshop->displayer()->isVisible(aRes)) { - isVisible = true; - canBeShaded = myWorkshop->displayer()->canBeShaded(aObject); - isShading = (myWorkshop->displayer()->displayMode(aObject) == XGUI_Displayer::Shading); - break; - } - } - if (isVisible) { - if (canBeShaded) { - if (isShading) - theMenu->addAction(action("WIREFRAME_CMD")); - else - theMenu->addAction(action("SHADING_CMD")); - } - theMenu->addSeparator(); - theMenu->addAction(action("SHOW_ONLY_CMD")); - theMenu->addAction(action("HIDE_CMD")); - } else - theMenu->addAction(action("SHOW_CMD")); - //theMenu->addAction(action("DELETE_CMD")); - } - if (myWorkshop->displayer()->objectsCount() > 0) - theMenu->addAction(action("HIDEALL_CMD")); - if (myWorkshop->canChangeColor()) - theMenu->addAction(action("COLOR_CMD")); + if (aModule) { + if (aModule->addViewerMenu(theMenu, myActions)) + theMenu->addSeparator(); } + XGUI_SelectionMgr* aSelMgr = myWorkshop->selector(); + QList aPrsList = aSelMgr->selection()->getSelected(ModuleBase_ISelection::Viewer); + int aSelected = aPrsList.size(); + QActionsList aActions; + if (aSelected == 1) { + ObjectPtr aObject = aPrsList.first().object(); + std::string aName = aObject->groupName(); + if (myViewerMenu.contains(aName)) + aActions = myViewerMenu[aName]; + } else if (aSelected > 1) { + aActions.append(action("HIDE_CMD")); + } + theMenu->addActions(aActions); + if (!myWorkshop->isSalomeMode()) { theMenu->addSeparator(); QMdiArea* aMDI = myWorkshop->mainWindow()->mdiArea(); @@ -294,18 +423,30 @@ void XGUI_ContextMenuMgr::addViewerItems(QMenu* theMenu) const aSubMenu->addActions(aMDI->actions()); } } - } -void XGUI_ContextMenuMgr::connectObjectBrowser() const +QStringList XGUI_ContextMenuMgr::actionObjectGroups(const QString& theName) { - connect(myWorkshop->objectBrowser(), SIGNAL(contextMenuRequested(QContextMenuEvent*)), this, - SLOT(onContextMenuRequest(QContextMenuEvent*))); + QStringList aGroups; + + QMap::const_iterator anIt = myObjBrowserMenus.begin(), + aLast = myObjBrowserMenus.end(); + for (; anIt != aLast; anIt++) { + QString aGroupName(anIt.key().c_str()); + if (aGroups.contains(aGroupName)) + continue; + QActionsList anActions = anIt.value(); + QActionsList::const_iterator anAIt = anActions.begin(), anALast = anActions.end(); + bool aFound = false; + for (; anAIt != anALast && !aFound; anAIt++) + aFound = (*anAIt)->data().toString() == theName; + if (aFound) + aGroups.append(aGroupName); + } + return aGroups; } -void XGUI_ContextMenuMgr::connectViewer() const +void XGUI_ContextMenuMgr::onRename() { - connect(myWorkshop->viewer(), SIGNAL(contextMenuRequested(QContextMenuEvent*)), this, - SLOT(onContextMenuRequest(QContextMenuEvent*))); + myWorkshop->objectBrowser()->onEditItem(); } -