Mantis issue 0020435: EDF 909 GEOM : Show Only Selected.

This commit is contained in:
jfa 2009-11-19 14:41:36 +00:00
parent 0e09658fa3
commit 37169d3f19
2 changed files with 309 additions and 320 deletions

View File

@ -35,16 +35,30 @@
#include <LightApp_SelectionMgr.h> #include <LightApp_SelectionMgr.h>
#include <OCCViewer_ViewModel.h>
#include <OCCViewer_ViewManager.h>
#include <SVTK_ViewModel.h>
#include <SALOME_Prs.h>
#include <SALOME_ListIteratorOfListIO.hxx>
#include <SUIT_ResourceMgr.h> #include <SUIT_ResourceMgr.h>
#include <SUIT_Desktop.h> #include <SUIT_Desktop.h>
#include <SUIT_OverrideCursor.h> #include <SUIT_OverrideCursor.h>
#include <SUIT_Session.h> #include <SUIT_Session.h>
#include <SUIT_ViewWindow.h>
#include <SUIT_ViewManager.h>
#include <QLabel> #include <QLabel>
#include <QListWidget> #include <QListWidget>
#include <QLineEdit> #include <QLineEdit>
#include <QMap> #include <QMap>
#include <AIS_ListOfInteractive.hxx>
#include <AIS_ListIteratorOfListOfInteractive.hxx>
#include <TopExp.hxx>
#include <TopExp_Explorer.hxx>
#include <TopTools_IndexedMapOfShape.hxx>
#include <TColStd_IndexedMapOfInteger.hxx> #include <TColStd_IndexedMapOfInteger.hxx>
#include <TColStd_MapOfInteger.hxx> #include <TColStd_MapOfInteger.hxx>
#include <TColStd_DataMapIteratorOfDataMapOfIntegerInteger.hxx> #include <TColStd_DataMapIteratorOfDataMapOfIntegerInteger.hxx>
@ -107,42 +121,53 @@ GroupGUI_GroupDlg::GroupGUI_GroupDlg (Mode mode, GeometryGUI* theGeometryGUI, QW
myShape2Name->setReadOnly(true); myShape2Name->setReadOnly(true);
myShape2Name->setEnabled(false); myShape2Name->setEnabled(false);
mySelectionWayGroupBox = new QGroupBox(tr("SHAPE_SEL_RESTR"), GroupMedium); myRestrictGroupBox = new QGroupBox(tr("SHAPE_SEL_RESTR"), GroupMedium);
mySelectionWayGroup = new QButtonGroup(mySelectionWayGroupBox); myRestrictGroup = new QButtonGroup(myRestrictGroupBox);
QRadioButton* allSubs = new QRadioButton(tr("NO_RESTR") , mySelectionWayGroupBox); QRadioButton* allSubs = new QRadioButton(tr("NO_RESTR") , myRestrictGroupBox);
QRadioButton* inPlaceSubs = new QRadioButton(tr("GEOM_PARTS_OF_SHAPE2"), mySelectionWayGroupBox); QRadioButton* inPlaceSubs = new QRadioButton(tr("GEOM_PARTS_OF_SHAPE2"), myRestrictGroupBox);
QRadioButton* shape2Subs = new QRadioButton(tr("SUBSHAPES_OF_SHAPE2") , mySelectionWayGroupBox); QRadioButton* shape2Subs = new QRadioButton(tr("SUBSHAPES_OF_SHAPE2") , myRestrictGroupBox);
QVBoxLayout* mySelWayLayout = new QVBoxLayout(mySelectionWayGroupBox); QVBoxLayout* aRestrictLayout = new QVBoxLayout(myRestrictGroupBox);
mySelWayLayout->setMargin(9); aRestrictLayout->setMargin(9);
mySelWayLayout->setSpacing(6); aRestrictLayout->setSpacing(6);
mySelWayLayout->addWidget(allSubs); aRestrictLayout->addWidget(allSubs);
mySelWayLayout->addWidget(inPlaceSubs); aRestrictLayout->addWidget(inPlaceSubs);
mySelWayLayout->addWidget(shape2Subs); aRestrictLayout->addWidget(shape2Subs);
mySelectionWayGroup->addButton(allSubs, ALL_SUBSHAPES); myRestrictGroup->addButton(allSubs, ALL_SUBSHAPES);
mySelectionWayGroup->addButton(inPlaceSubs, GET_IN_PLACE); myRestrictGroup->addButton(inPlaceSubs, GET_IN_PLACE);
mySelectionWayGroup->addButton(shape2Subs, SUBSHAPES_OF_SHAPE2); myRestrictGroup->addButton(shape2Subs, SUBSHAPES_OF_SHAPE2);
allSubs->setChecked(true); allSubs->setChecked(true);
mySelAllBtn = new QPushButton(tr("SELECT_ALL"), GroupMedium); myShowOnlyBtn = new QPushButton(tr("Show only selected"), GroupMedium);
myAddBtn = new QPushButton(tr("ADD"), GroupMedium); myHideSelBtn = new QPushButton(tr("Hide selected"), GroupMedium);
myRemBtn = new QPushButton(tr("REMOVE"), GroupMedium); myShowAllBtn = new QPushButton(tr("Show all sub-shapes"), GroupMedium);
mySelAllBtn = new QPushButton(tr("SELECT_ALL"), GroupMedium);
myAddBtn = new QPushButton(tr("ADD"), GroupMedium);
myRemBtn = new QPushButton(tr("REMOVE"), GroupMedium);
myIdList = new QListWidget(GroupMedium); myIdList = new QListWidget(GroupMedium);
myIdList->setSelectionMode(QAbstractItemView::ExtendedSelection); myIdList->setSelectionMode(QAbstractItemView::ExtendedSelection);
myIdList->setFlow(QListView::TopToBottom); myIdList->setFlow(QListView::TopToBottom);
myIdList->setWrapping(true); myIdList->setWrapping(true);
aMedLayout->addWidget(aMainLabel, 0, 0); aMedLayout->addWidget(aMainLabel, 0, 0);
aMedLayout->addWidget(mySelBtn, 0, 1); aMedLayout->addWidget(mySelBtn, 0, 1);
aMedLayout->addWidget(myMainName, 0, 2, 1, 2); aMedLayout->addWidget(myMainName, 0, 2, 1, 2);
aMedLayout->addWidget(aSecondLabel, 1, 0); aMedLayout->addWidget(aSecondLabel, 1, 0);
aMedLayout->addWidget(mySelBtn2, 1, 1); aMedLayout->addWidget(mySelBtn2, 1, 1);
aMedLayout->addWidget(myShape2Name, 1, 2, 1, 2); aMedLayout->addWidget(myShape2Name, 1, 2, 1, 2);
aMedLayout->addWidget(mySelectionWayGroupBox, 2, 0, 3, 3); aMedLayout->addWidget(myRestrictGroupBox, 2, 0, 3, 3);
aMedLayout->addWidget(mySelAllBtn, 2, 3);
aMedLayout->addWidget(myAddBtn, 3, 3); aMedLayout->addWidget(myShowOnlyBtn, 2, 3);
aMedLayout->addWidget(myRemBtn, 4, 3); aMedLayout->addWidget(myHideSelBtn, 3, 3);
aMedLayout->addWidget(myIdList, 5, 0, 1, 4); aMedLayout->addWidget(myShowAllBtn, 4, 3);
aMedLayout->addWidget(mySelAllBtn, 5, 3);
aMedLayout->addWidget(myAddBtn, 6, 3);
aMedLayout->addWidget(myRemBtn, 7, 3);
aMedLayout->addWidget(myIdList, 5, 0, 3, 3);
aMedLayout->setRowStretch(5, 1); aMedLayout->setRowStretch(5, 1);
QVBoxLayout* layout = new QVBoxLayout(centralWidget()); QVBoxLayout* layout = new QVBoxLayout(centralWidget());
@ -164,7 +189,6 @@ GroupGUI_GroupDlg::~GroupGUI_GroupDlg()
//================================================================================= //=================================================================================
void GroupGUI_GroupDlg::Init() void GroupGUI_GroupDlg::Init()
{ {
// san -- TODO: clear selected sub-shapes...
LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr(); LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
//unset shape type to avoid preparation of selection before exact user shape type selection //unset shape type to avoid preparation of selection before exact user shape type selection
@ -214,14 +238,17 @@ void GroupGUI_GroupDlg::Init()
connect(aSelMgr, SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument())); connect(aSelMgr, SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument()));
connect(buttonOk(), SIGNAL(clicked()), this, SLOT(ClickOnOk() )); connect(buttonOk(), SIGNAL(clicked()), this, SLOT(ClickOnOk()));
connect(buttonApply(), SIGNAL(clicked()), this, SLOT(ClickOnApply())); connect(buttonApply(), SIGNAL(clicked()), this, SLOT(ClickOnApply()));
connect(mySelectionWayGroup, SIGNAL(buttonClicked(int)), this, SLOT(SetEditCurrentArgument())); connect(myRestrictGroup, SIGNAL(buttonClicked(int)), this, SLOT(SetEditCurrentArgument()));
connect(mySelAllBtn, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument())); connect(mySelAllBtn, SIGNAL(clicked()), this, SLOT(selectAllSubShapes()));
connect(myAddBtn, SIGNAL(clicked()), this, SLOT(add())); connect(myAddBtn, SIGNAL(clicked()), this, SLOT(add()));
connect(myRemBtn, SIGNAL(clicked()), this, SLOT(remove())); connect(myRemBtn, SIGNAL(clicked()), this, SLOT(remove()));
connect(myIdList, SIGNAL(itemSelectionChanged()), this, SLOT(selectionChanged())); connect(myShowOnlyBtn, SIGNAL(clicked()), this, SLOT(showOnlySelected()));
connect(myHideSelBtn, SIGNAL(clicked()), this, SLOT(showOnlySelected()));
connect(myShowAllBtn, SIGNAL(clicked()), this, SLOT(showOnlySelected()));
connect(myIdList, SIGNAL(itemSelectionChanged()), this, SLOT(selectionChanged()));
setInPlaceObj(GEOM::GEOM_Object::_nil()); setInPlaceObj(GEOM::GEOM_Object::_nil());
@ -247,6 +274,7 @@ void GroupGUI_GroupDlg::enterEvent(QEvent* e)
void GroupGUI_GroupDlg::closeEvent(QCloseEvent* e) void GroupGUI_GroupDlg::closeEvent(QCloseEvent* e)
{ {
setInPlaceObj(GEOM::GEOM_Object::_nil()); setInPlaceObj(GEOM::GEOM_Object::_nil());
erasePreview(true);
GEOMBase_Skeleton::closeEvent(e); GEOMBase_Skeleton::closeEvent(e);
} }
@ -308,10 +336,7 @@ void GroupGUI_GroupDlg::SetEditCurrentArgument()
myEditCurrentArgument = myMainName; myEditCurrentArgument = myMainName;
myShape2Name->setText(""); myShape2Name->setText("");
} }
else if (send == mySelAllBtn) { else if (send == mySelBtn2 || sender() == myRestrictGroup) {
myEditCurrentArgument = 0;
}
else if (send == mySelBtn2 || sender() == mySelectionWayGroup) {
setInPlaceObj(GEOM::GEOM_Object::_nil()); setInPlaceObj(GEOM::GEOM_Object::_nil());
myShape2Name->setText(""); myShape2Name->setText("");
if (subSelectionWay() != ALL_SUBSHAPES) { if (subSelectionWay() != ALL_SUBSHAPES) {
@ -324,10 +349,7 @@ void GroupGUI_GroupDlg::SetEditCurrentArgument()
activateSelection(); activateSelection();
if (send == mySelAllBtn) updateState();
selectAllSubShapes();
else
updateState();
} }
//================================================================================= //=================================================================================
@ -384,30 +406,11 @@ void GroupGUI_GroupDlg::onGetInPlace()
//================================================================================= //=================================================================================
void GroupGUI_GroupDlg::setInPlaceObj(GEOM::GEOM_Object_var theObj, const bool isVisible) void GroupGUI_GroupDlg::setInPlaceObj(GEOM::GEOM_Object_var theObj, const bool isVisible)
{ {
if (! myInPlaceObj->_is_equivalent(theObj)) if (!myInPlaceObj->_is_equivalent(theObj))
{ {
const char* tmpName = "__InPlaceObj__";
// remove old InPlaceObj
if (!myInPlaceObj->_is_nil()) {
if (myInPlaceObjSelectState == GET_IN_PLACE ||
myInPlaceObjSelectState == SUBSHAPES_OF_INVISIBLE_SHAPE2) {
// hide temporary object or initially invisible shape 2 (issue 0014047)
GEOM_Displayer aDisplayer(getStudy());
aDisplayer.Erase(myInPlaceObj, true);
}
if (_PTR(SObject) SO = getStudy()->studyDS()->FindObject(tmpName)) {
getStudy()->studyDS()->NewBuilder()->RemoveObjectWithChildren(SO);
getGeomEngine()->RemoveObject(myInPlaceObj);
}
}
// publish InPlaceObj to enable localSelection(InPlaceObj)
if (!theObj->_is_nil() && subSelectionWay() == GET_IN_PLACE) {
SALOMEDS::Study_var aStudyDS = GeometryGUI::ClientStudyToStudy(getStudy()->studyDS());
SALOMEDS::SObject_var aSO =
getGeomEngine()->AddInStudy(aStudyDS, theObj, tmpName, myMainObj);
}
myInPlaceObj = theObj; myInPlaceObj = theObj;
} }
// build map of indices // build map of indices
myMain2InPlaceIndices.Clear(); myMain2InPlaceIndices.Clear();
if (!myInPlaceObj->_is_nil()) { if (!myInPlaceObj->_is_nil()) {
@ -439,15 +442,16 @@ void GroupGUI_GroupDlg::SelectionIntoArgument()
return; return;
} }
LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
SALOME_ListIO aSelList;
aSelMgr->selectedObjects(aSelList);
if (myEditCurrentArgument == myMainName) { // Selection of a main shape is active if (myEditCurrentArgument == myMainName) { // Selection of a main shape is active
myEditCurrentArgument->setText(""); myEditCurrentArgument->setText("");
myIdList->clear(); myIdList->clear();
if (aSelList.Extent() == 1) { LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
SALOME_ListIO aSelList;
aSelMgr->selectedObjects(aSelList);
int nbSel = aSelList.Extent();
if (nbSel == 1) {
Standard_Boolean aResult = Standard_False; Standard_Boolean aResult = Standard_False;
GEOM::GEOM_Object_var anObj = GEOM::GEOM_Object_var anObj =
GEOMBase::ConvertIOinGEOMObject(aSelList.First(), aResult); GEOMBase::ConvertIOinGEOMObject(aSelList.First(), aResult);
@ -459,11 +463,11 @@ void GroupGUI_GroupDlg::SelectionIntoArgument()
myEditCurrentArgument = 0; myEditCurrentArgument = 0;
activateSelection(); activateSelection();
updateState(); updateState();
return;
} }
} }
else {
myMainObj = GEOM::GEOM_Object::_nil(); myMainObj = GEOM::GEOM_Object::_nil();
}
} }
else { // an attempt to synchronize list box selection with 3d viewer else { // an attempt to synchronize list box selection with 3d viewer
if (myBusy) { if (myBusy) {
@ -475,77 +479,9 @@ void GroupGUI_GroupDlg::SelectionIntoArgument()
myIdList->clearSelection(); myIdList->clearSelection();
TColStd_IndexedMapOfInteger aMapIndex; TColStd_IndexedMapOfInteger aMapIndex;
int nbSel = getSelectedSubshapes(aMapIndex);
LightApp_SelectionMgr::MapEntryOfMapOfInteger aMap; if (nbSel) {
aSelMgr->selectedSubOwners(aMap);
if (aMap.Size() == 1)
aMapIndex = LightApp_SelectionMgr::MapEntryOfMapOfInteger::Iterator(aMap).Value();
bool subselected = aMapIndex.Extent();
// convert inPlace indices to main indices
if (subselected && subSelectionWay() != ALL_SUBSHAPES)
{
TColStd_IndexedMapOfInteger aMapIndex2;
TColStd_DataMapIteratorOfDataMapOfIntegerInteger m2ip(myMain2InPlaceIndices);
for (; m2ip.More(); m2ip.Next()) {
int inPlaceId = m2ip.Value();
if (aMapIndex.Contains(inPlaceId)) {
aMapIndex2.Add(m2ip.Key());
}
}
aMapIndex = aMapIndex2;
}
// try to find out and process the object browser selection
if (!subselected) {
globalSelection(GEOM_ALLSHAPES);
GEOM::ListOfGO anObjects;
GEOMBase::ConvertListOfIOInListOfGO(aSelList, anObjects);
GEOM::GEOM_ILocalOperations_var aLocOp = getGeomEngine()->GetILocalOperations(getStudyId());
GEOM::GEOM_IShapesOperations_var aShapesOp = getGeomEngine()->GetIShapesOperations(getStudyId());
for (int i = 0; i < anObjects.length(); i++)
{
GEOM::GEOM_Object_var aGeomObj = anObjects[i];
GEOM::ListOfGO_var aSubObjects = new GEOM::ListOfGO();
TopoDS_Shape aShape;
if (GEOMBase::GetShape(aGeomObj, aShape, getShapeType()))
{
aSubObjects->length(1);
aSubObjects[0] = aGeomObj;
}
else if (aGeomObj->GetType() == GEOM_GROUP)
aSubObjects = aShapesOp->MakeExplode(aGeomObj, getShapeType(), false);
else
continue;
for (int i = 0; i < aSubObjects->length(); i++)
{
TopoDS_Shape aShape;
if (GEOMBase::GetShape(aSubObjects[i], aShape, getShapeType()))
{
CORBA::Long anIndex;
anIndex = aLocOp->GetSubShapeIndex(myMainObj, aSubObjects[i]);
if (anIndex >= 0) {
if (subSelectionWay() != ALL_SUBSHAPES &&
! myMain2InPlaceIndices.IsBound(anIndex))
continue;
aMapIndex.Add(anIndex);
}
}
}
}
if (!myMainObj->_is_nil() && myIsShapeType)
if (subSelectionWay() == ALL_SUBSHAPES)
localSelection(myMainObj, getShapeType());
else if (!myInPlaceObj->_is_nil())
localSelection(myInPlaceObj, getShapeType());
}
if (aMapIndex.Extent() >= 1) {
QMap<int, int> aMap; QMap<int, int> aMap;
for (int i = 0, n = myIdList->count(); i < n; i++) for (int i = 0, n = myIdList->count(); i < n; i++)
aMap.insert(myIdList->item(i)->text().toInt(), i); aMap.insert(myIdList->item(i)->text().toInt(), i);
@ -556,9 +492,9 @@ void GroupGUI_GroupDlg::SelectionIntoArgument()
} }
} }
myIdList->blockSignals(isBlocked); myIdList->blockSignals(isBlocked);
}
updateState(); updateState(nbSel);
}
} }
//================================================================================= //=================================================================================
@ -572,9 +508,11 @@ void GroupGUI_GroupDlg::ConstructorsClicked(int constructorId)
myIsShapeType = true; myIsShapeType = true;
myIdList->clear(); myIdList->clear();
myEditCurrentArgument = 0;
setInPlaceObj(myInPlaceObj); // to rebuild myMain2InPlaceIndices
activateSelection(); activateSelection();
updateState(); updateState();
setInPlaceObj(myInPlaceObj); // to rebuild myMain2InPlaceIndices
} }
//================================================================================= //=================================================================================
@ -592,7 +530,7 @@ void GroupGUI_GroupDlg::selectAllSubShapes()
if (aSubShapes->length() > 0) { if (aSubShapes->length() > 0) {
if (subSelectionWay() == ALL_SUBSHAPES) if (subSelectionWay() == ALL_SUBSHAPES)
{ {
myIdList->clear(); myIdList->clear(); // for sorted final list?
if (!aShOp->IsDone()) if (!aShOp->IsDone())
return; return;
@ -601,10 +539,11 @@ void GroupGUI_GroupDlg::selectAllSubShapes()
{ {
aSubShapes = new GEOM::ListOfLong(); aSubShapes = new GEOM::ListOfLong();
aSubShapes->length(myMain2InPlaceIndices.Extent()); aSubShapes->length(myMain2InPlaceIndices.Extent());
TColStd_DataMapIteratorOfDataMapOfIntegerInteger m2ip(myMain2InPlaceIndices); TColStd_DataMapIteratorOfDataMapOfIntegerInteger m2ip (myMain2InPlaceIndices);
for (int i = 0; m2ip.More(); i++, m2ip.Next()) for (int i = 0; m2ip.More(); i++, m2ip.Next())
aSubShapes[ i ] = m2ip.Key(); aSubShapes[i] = m2ip.Key();
} }
bool isBlocked = myIdList->signalsBlocked(); bool isBlocked = myIdList->signalsBlocked();
myIdList->blockSignals(true); myIdList->blockSignals(true);
@ -631,83 +570,118 @@ void GroupGUI_GroupDlg::selectAllSubShapes()
} }
} }
//=================================================================================
// function : showOnlySelected
// purpose :
//=================================================================================
void GroupGUI_GroupDlg::showOnlySelected()
{
if (CORBA::is_nil(myMainObj) || !myIsShapeType)
return;
QPushButton* send = (QPushButton*)sender();
if (send == myShowAllBtn) {
activateSelection();
return;
}
LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
SALOME_ListIO aSelList;
aSelMgr->selectedObjects(aSelList);
GEOM_Displayer* aDisplayer = getDisplayer();
if (send == myHideSelBtn) {
aDisplayer->Erase(aSelList, false, true);
}
else {
aDisplayer->EraseAll();
aDisplayer->Display(aSelList, true);
}
}
//=================================================================================
// function : getSelectedSubshapes
// purpose :
//=================================================================================
int GroupGUI_GroupDlg::getSelectedSubshapes (TColStd_IndexedMapOfInteger& theMapIndex)
{
theMapIndex.Clear();
SalomeApp_Application* app = myGeomGUI->getApp();
if (!app) return 0;
LightApp_SelectionMgr* aSelMgr = app->selectionMgr();
SALOME_ListIO aSelList;
aSelMgr->selectedObjects(aSelList);
// try to find out and process the global selection
// (of not published objects and of published sub-shapes)
{
SALOME_ListIteratorOfListIO anIter (aSelList);
for (int i = 0; anIter.More(); anIter.Next(), i++)
{
Handle(SALOME_InteractiveObject) anIObj = anIter.Value();
QString anEntry = anIObj->getEntry();
QString str = "_";
int index = anEntry.lastIndexOf(str);
if (index > 0) // selection among special preview
{
anEntry.remove(0, index+1);
int anIndex = anEntry.toInt();
if (anIndex)
theMapIndex.Add(anIndex);
}
else // selection among published shapes
{
SalomeApp_Study* appStudy = dynamic_cast<SalomeApp_Study*>(app->activeStudy());
if (!appStudy) return 0;
_PTR(Study) aStudy = appStudy->studyDS();
_PTR(SObject) aSObj (aStudy->FindObjectID(anEntry.toLatin1().constData()));
GEOM::GEOM_Object_var aGeomObj =
GEOM::GEOM_Object::_narrow(GeometryGUI::ClientSObjectToObject(aSObj));
TopoDS_Shape aShape;
if (GEOMBase::GetShape(aGeomObj, aShape)) {
if (aGeomObj->GetType() == GEOM_GROUP || aShape.ShapeType() == getShapeType()) {
TopTools_IndexedMapOfShape aMainMap;
TopoDS_Shape aMainShape = GEOM_Client().GetShape(GeometryGUI::GetGeomGen(), myMainObj);
TopExp::MapShapes(aMainShape, aMainMap);
TopExp_Explorer anExp (aShape, getShapeType());
for (; anExp.More(); anExp.Next()) {
TopoDS_Shape aSubShape = anExp.Current();
int anIndex = aMainMap.FindIndex(aSubShape);
if (anIndex >= 0) {
if (subSelectionWay() != ALL_SUBSHAPES &&
!myMain2InPlaceIndices.IsBound(anIndex))
continue;
theMapIndex.Add(anIndex);
}
}
}
}
}
} // for aSelList
}
return theMapIndex.Extent();
}
//================================================================================= //=================================================================================
// function : add // function : add
// purpose : // purpose :
//================================================================================= //=================================================================================
void GroupGUI_GroupDlg::add() void GroupGUI_GroupDlg::add()
{ {
SalomeApp_Application* app = myGeomGUI->getApp();
if (!app) return;
LightApp_SelectionMgr* aSelMgr = app->selectionMgr();
if (!aSelMgr) return;
TColStd_IndexedMapOfInteger aMapIndex; TColStd_IndexedMapOfInteger aMapIndex;
LightApp_SelectionMgr::MapEntryOfMapOfInteger aMapSubOwners; int nbSel = getSelectedSubshapes(aMapIndex);
aSelMgr->selectedSubOwners(aMapSubOwners);
if (aMapSubOwners.Size() == 1)
aMapIndex = LightApp_SelectionMgr::MapEntryOfMapOfInteger::Iterator(aMapSubOwners).Value();
GEOM::ListOfGO anObjects;
// get selected sub-shapes of myInPlaceObj
if (aMapIndex.Extent() > 0 && !myInPlaceObj->_is_nil())
{
GEOM::GEOM_IShapesOperations_var aShapesOp = getGeomEngine()->GetIShapesOperations(getStudyId());
anObjects.length(aMapIndex.Extent());
for (int i = 1; i <= aMapIndex.Extent(); i++)
anObjects[ i-1 ] = aShapesOp->GetSubShape(myInPlaceObj, aMapIndex(i));
aMapIndex.Clear();
}
// try to find out and process the object browser selection or InPlace sub-shapes
if (!aMapIndex.Extent())
{
if (anObjects.length() == 0) {
SALOME_ListIO aSelIOs;
aSelMgr->selectedObjects(aSelIOs);
GEOMBase::ConvertListOfIOInListOfGO(aSelIOs, anObjects);
}
GEOM::GEOM_ILocalOperations_var aLocOp = getGeomEngine()->GetILocalOperations(getStudyId());
GEOM::GEOM_IShapesOperations_var aShapesOp = getGeomEngine()->GetIShapesOperations(getStudyId());
for (int i = 0; i < anObjects.length(); i++)
{
GEOM::GEOM_Object_var aGeomObj = anObjects[i];
GEOM::ListOfGO_var aSubObjects = new GEOM::ListOfGO();
TopoDS_Shape aShape;
if (GEOMBase::GetShape(aGeomObj, aShape, getShapeType()))
{
aSubObjects->length(1);
aSubObjects[0] = aGeomObj;
}
else if (aGeomObj->GetType() == GEOM_GROUP)
aSubObjects = aShapesOp->MakeExplode(aGeomObj, getShapeType(), false);
else
break;
for (int i = 0; i < aSubObjects->length(); i++)
{
TopoDS_Shape aShape;
if (GEOMBase::GetShape(aSubObjects[i], aShape, getShapeType()))
{
CORBA::Long anIndex;
anIndex = aLocOp->GetSubShapeIndex(myMainObj, aSubObjects[i]);
if (anIndex >= 0)
aMapIndex.Add(anIndex);
}
}
}
}
TColStd_MapOfInteger aMap; TColStd_MapOfInteger aMap;
for (int i = 0, n = myIdList->count(); i < n; i++) for (int i = 0, n = myIdList->count(); i < n; i++)
aMap.Add(myIdList->item(i)->text().toInt()); aMap.Add(myIdList->item(i)->text().toInt());
if (aMapIndex.Extent() >= 1) { if (nbSel > 0) {
bool isBlocked = myIdList->signalsBlocked(); bool isBlocked = myIdList->signalsBlocked();
myIdList->blockSignals(true); myIdList->blockSignals(true);
@ -735,7 +709,7 @@ void GroupGUI_GroupDlg::remove()
bool isBlocked = myIdList->signalsBlocked(); bool isBlocked = myIdList->signalsBlocked();
myIdList->blockSignals(true); myIdList->blockSignals(true);
QListIterator<QListWidgetItem*> it(myIdList->selectedItems()); QListIterator<QListWidgetItem*> it (myIdList->selectedItems());
while (it.hasNext()) while (it.hasNext())
delete it.next(); delete it.next();
@ -750,7 +724,7 @@ void GroupGUI_GroupDlg::remove()
//================================================================================= //=================================================================================
int GroupGUI_GroupDlg::subSelectionWay() const int GroupGUI_GroupDlg::subSelectionWay() const
{ {
return mySelectionWayGroup->checkedId(); return myRestrictGroup->checkedId();
} }
//================================================================================= //=================================================================================
@ -796,19 +770,60 @@ void GroupGUI_GroupDlg::setShapeType(const TopAbs_ShapeEnum theType)
//================================================================================= //=================================================================================
void GroupGUI_GroupDlg::activateSelection() void GroupGUI_GroupDlg::activateSelection()
{ {
globalSelection(GEOM_ALLSHAPES); erasePreview(false);
// local selection // local selection
if (!myMainObj->_is_nil() && if (!myMainObj->_is_nil() &&
!myEditCurrentArgument && !myEditCurrentArgument &&
myIsShapeType) // check if shape type is already choosen by user myIsShapeType) // check if shape type is already choosen by user
{ {
GEOM_Displayer* aDisplayer = getDisplayer();
SUIT_ViewWindow* aViewWindow = 0;
SUIT_Study* activeStudy = SUIT_Session::session()->activeApplication()->activeStudy();
if (activeStudy)
aViewWindow = SUIT_Session::session()->activeApplication()->desktop()->activeWindow();
if (aViewWindow == 0) return;
SUIT_ViewManager* aViewManager = aViewWindow->getViewManager();
if (aViewManager->getType() != OCCViewer_Viewer::Type() &&
aViewManager->getType() != SVTK_Viewer::Type())
return;
SUIT_ViewModel* aViewModel = aViewManager->getViewModel();
SALOME_View* aView = dynamic_cast<SALOME_View*>(aViewModel);
if (aView == 0) return;
TopoDS_Shape aMainShape = GEOM_Client().GetShape(GeometryGUI::GetGeomGen(), myMainObj);
TopoDS_Shape aRestrictionShape;
if (subSelectionWay() == ALL_SUBSHAPES) if (subSelectionWay() == ALL_SUBSHAPES)
localSelection(myMainObj, getShapeType()); aRestrictionShape = aMainShape;
else if (!myInPlaceObj->_is_nil()) else if (!myInPlaceObj->_is_nil())
localSelection(myInPlaceObj, getShapeType()); aRestrictionShape = GEOM_Client().GetShape(GeometryGUI::GetGeomGen(), myInPlaceObj);
else ;
TopTools_IndexedMapOfShape aSubShapesMap;
TopExp::MapShapes(aMainShape, aSubShapesMap);
CORBA::String_var aMainEntry = myMainObj->GetStudyEntry();
QString anEntryBase = aMainEntry.in();
TopExp_Explorer anExp (aRestrictionShape, getShapeType());
for (; anExp.More(); anExp.Next())
{
TopoDS_Shape aSubShape = anExp.Current();
int index = aSubShapesMap.FindIndex(aSubShape);
QString anEntry = anEntryBase + QString("_%1").arg(index);
SALOME_Prs* aPrs = aDisplayer->buildSubshapePresentation(aSubShape, anEntry, aView);
if (aPrs) {
displayPreview(aPrs, true, false); // append, do not update
}
}
aDisplayer->UpdateViewer();
} }
globalSelection(GEOM_ALLSHAPES);
SelectionIntoArgument(); SelectionIntoArgument();
} }
@ -816,85 +831,15 @@ void GroupGUI_GroupDlg::activateSelection()
// function : updateState // function : updateState
// purpose : // purpose :
//================================================================================= //=================================================================================
void GroupGUI_GroupDlg::updateState() void GroupGUI_GroupDlg::updateState (bool isAdd)
{ {
SalomeApp_Application* app = myGeomGUI->getApp();
if (!app) return;
LightApp_SelectionMgr* aSelMgr = app->selectionMgr();
if (!aSelMgr) return;
TColStd_IndexedMapOfInteger aMapIndex;
LightApp_SelectionMgr::MapEntryOfMapOfInteger aMapSubOwners;
aSelMgr->selectedSubOwners(aMapSubOwners);
if (aMapSubOwners.Size() == 1)
aMapIndex = LightApp_SelectionMgr::MapEntryOfMapOfInteger::Iterator(aMapSubOwners).Value();
bool isAdd = false;
// try to find out and process the object browser selection
if (!aMapIndex.Extent() && !CORBA::is_nil(myMainObj)) {
GEOM::ListOfGO anObjects;
SALOME_ListIO aSelIOs;
aSelMgr->selectedObjects(aSelIOs);
GEOMBase::ConvertListOfIOInListOfGO(aSelIOs, anObjects);
GEOM::GEOM_ILocalOperations_var aLocOp = getGeomEngine()->GetILocalOperations(getStudyId());
GEOM::GEOM_IShapesOperations_var aShapesOp = getGeomEngine()->GetIShapesOperations(getStudyId());
isAdd = true;
for (int i = 0; i < anObjects.length(); i++)
{
GEOM::GEOM_Object_var aGeomObj = anObjects[i];
GEOM::ListOfGO_var aSubObjects = new GEOM::ListOfGO();
TopoDS_Shape aShape;
if (GEOMBase::GetShape(aGeomObj, aShape, getShapeType())) {
aSubObjects->length(1);
aSubObjects[0] = aGeomObj;
}
else if (aGeomObj->GetType() == GEOM_GROUP) {
aSubObjects = aShapesOp->MakeExplode(aGeomObj, getShapeType(), false);
}
else {
aMapIndex.Clear();
break;
}
for (int i = 0; i < aSubObjects->length(); i++)
{
TopoDS_Shape aShape;
aSubObjects[i];
if (GEOMBase::GetShape(aSubObjects[i], aShape, getShapeType()))
{
CORBA::Long anIndex;
anIndex = aLocOp->GetSubShapeIndex(myMainObj, aSubObjects[i]);
if (anIndex >= 0)
aMapIndex.Add(anIndex);
else
isAdd = false;
}
else
isAdd = false;
if (!isAdd) {
aMapIndex.Clear();
break;
}
}
if (!isAdd) {
aMapIndex.Clear();
break;
}
}
}
isAdd = aMapIndex.Extent() > 0;
myAddBtn->setEnabled(!myEditCurrentArgument && !CORBA::is_nil(myMainObj) && isAdd); myAddBtn->setEnabled(!myEditCurrentArgument && !CORBA::is_nil(myMainObj) && isAdd);
//myShowOnlyBtn->setEnabled(!myEditCurrentArgument && !CORBA::is_nil(myMainObj) && isAdd);
bool hasSel = myIdList->selectedItems().count() > 0; bool hasSel = myIdList->selectedItems().count() > 0;
myRemBtn->setEnabled(hasSel); myRemBtn->setEnabled(hasSel);
mySelectionWayGroupBox->setEnabled(!CORBA::is_nil(myMainObj)); myRestrictGroupBox->setEnabled(!CORBA::is_nil(myMainObj));
mySelAllBtn->setEnabled(!CORBA::is_nil(myMainObj)); mySelAllBtn->setEnabled(!CORBA::is_nil(myMainObj));
mySelBtn2->setEnabled( subSelectionWay() != ALL_SUBSHAPES); mySelBtn2->setEnabled( subSelectionWay() != ALL_SUBSHAPES);
@ -921,19 +866,6 @@ void GroupGUI_GroupDlg::highlightSubShapes()
if (CORBA::is_nil(myMainObj)) if (CORBA::is_nil(myMainObj))
return; return;
Standard_Boolean isOk;
char* objIOR;
if (myInPlaceObj->_is_nil())
objIOR = GEOMBase::GetIORFromObject(myMainObj);
else
objIOR = GEOMBase::GetIORFromObject(myInPlaceObj);
Handle(GEOM_AISShape) aSh = GEOMBase::ConvertIORinGEOMAISShape(objIOR, isOk, true);
free(objIOR);
if (!isOk || aSh.IsNull())
return;
TColStd_MapOfInteger anIds; TColStd_MapOfInteger anIds;
myBusy = true; myBusy = true;
@ -943,29 +875,66 @@ void GroupGUI_GroupDlg::highlightSubShapes()
{ {
if (myIdList->item(ii)->isSelected()) { if (myIdList->item(ii)->isSelected()) {
int id = myIdList->item(ii)->text().toInt(); int id = myIdList->item(ii)->text().toInt();
if (subSelectionWay() != ALL_SUBSHAPES) if (subSelectionWay() != ALL_SUBSHAPES &&
{ !myMain2InPlaceIndices.IsBound(id)) {
if (myMain2InPlaceIndices.IsBound(id)) myIdList->item(ii)->setSelected(false);
id = myMain2InPlaceIndices(id); }
else { else {
myIdList->item(ii)->setSelected(false); anIds.Add(id);
continue;
}
} }
anIds.Add(id);
} }
} }
SalomeApp_Application* app = myGeomGUI->getApp(); SalomeApp_Application* app = myGeomGUI->getApp();
LightApp_SelectionMgr* aSelMgr = app->selectionMgr(); LightApp_SelectionMgr* aSelMgr = app->selectionMgr();
aSelMgr->clearSelected(); aSelMgr->clearSelected();
aSelMgr->AddOrRemoveIndex(aSh->getIO(), anIds, false); SUIT_ViewWindow* aViewWindow = 0;
SUIT_Study* activeStudy = app->activeStudy();
if (activeStudy)
aViewWindow = app->desktop()->activeWindow();
if (aViewWindow == 0) return;
SUIT_ViewManager* aViewManager = aViewWindow->getViewManager();
if (aViewManager->getType() != OCCViewer_Viewer::Type() &&
aViewManager->getType() != SVTK_Viewer::Type())
return;
SUIT_ViewModel* aViewModel = aViewManager->getViewModel();
SALOME_View* aView = dynamic_cast<SALOME_View*>(aViewModel);
if (aView == 0) return;
// TODO: use here GEOMBase_Helper::myPreview instead of ic->DisplayedObjects()
OCCViewer_Viewer* v3d = ((OCCViewer_ViewManager*)aViewManager)->getOCCViewer();
Handle(AIS_InteractiveContext) ic = v3d->getAISContext();
AIS_ListOfInteractive List;
ic->DisplayedObjects(List);
SALOME_ListIO aSelList;
AIS_ListIteratorOfListOfInteractive ite (List);
for (; ite.More(); ite.Next()) {
if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) {
Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value());
if (aSh->hasIO()) {
Handle(SALOME_InteractiveObject) anIO = aSh->getIO();
QString anEntry = anIO->getEntry();
int index = anEntry.lastIndexOf("_");
anEntry.remove(0, index+1);
int anIndex = anEntry.toInt();
if (anIds.Contains(anIndex))
aSelList.Append(anIO);
}
}
}
aSelMgr->setSelectedObjects(aSelList);
myBusy = false; myBusy = false;
if (nn < 3000) if (nn < 3000)
updateState(); updateState(aSelList.Extent() > 0);
else { else {
myAddBtn->setEnabled(true);
myAddBtn->setEnabled(true); myAddBtn->setEnabled(true);
myRemBtn->setEnabled(true); myRemBtn->setEnabled(true);
} }
@ -1016,8 +985,6 @@ bool GroupGUI_GroupDlg::isValid(QString& theMessage)
//================================================================================= //=================================================================================
bool GroupGUI_GroupDlg::execute(ObjectList& objects) bool GroupGUI_GroupDlg::execute(ObjectList& objects)
{ {
setInPlaceObj(GEOM::GEOM_Object::_nil());
GEOM::GEOM_IGroupOperations_var anOp = GEOM::GEOM_IGroupOperations::_narrow(getOperation()); GEOM::GEOM_IGroupOperations_var anOp = GEOM::GEOM_IGroupOperations::_narrow(getOperation());
GEOM::GEOM_Object_var aGroup; GEOM::GEOM_Object_var aGroup;
@ -1071,3 +1038,18 @@ bool GroupGUI_GroupDlg::execute(ObjectList& objects)
return true; return true;
} }
//================================================================
// Function : getFather
// Purpose : Get father object for object to be added in study
// ( called with addInStudy method )
//================================================================
GEOM::GEOM_Object_ptr GroupGUI_GroupDlg::getFather(GEOM::GEOM_Object_ptr theObj)
{
GEOM::GEOM_Object_var aFatherObj;
if (theObj->GetType() == GEOM_GROUP) {
GEOM::GEOM_IGroupOperations_var anOper = GEOM::GEOM_IGroupOperations::_narrow(getOperation());
aFatherObj = anOper->GetMainShape(theObj);
}
return aFatherObj._retn();
}

View File

@ -30,6 +30,7 @@
#include <TopAbs_ShapeEnum.hxx> #include <TopAbs_ShapeEnum.hxx>
#include <TColStd_DataMapOfIntegerInteger.hxx> #include <TColStd_DataMapOfIntegerInteger.hxx>
#include <TColStd_IndexedMapOfInteger.hxx>
class QGroupBox; class QGroupBox;
class QLineEdit; class QLineEdit;
@ -58,6 +59,7 @@ protected:
virtual GEOM::GEOM_IOperations_ptr createOperation(); virtual GEOM::GEOM_IOperations_ptr createOperation();
virtual bool isValid( QString& ); virtual bool isValid( QString& );
virtual bool execute( ObjectList& ); virtual bool execute( ObjectList& );
virtual GEOM::GEOM_Object_ptr getFather( GEOM::GEOM_Object_ptr );
void closeEvent( QCloseEvent* ); void closeEvent( QCloseEvent* );
@ -73,6 +75,7 @@ private slots:
void selectAllSubShapes(); void selectAllSubShapes();
void add(); void add();
void remove(); void remove();
void showOnlySelected();
void selectionChanged(); void selectionChanged();
private: private:
@ -82,10 +85,11 @@ private:
TopAbs_ShapeEnum getShapeType() const; TopAbs_ShapeEnum getShapeType() const;
void setShapeType( const TopAbs_ShapeEnum ); void setShapeType( const TopAbs_ShapeEnum );
void activateSelection(); void activateSelection();
void updateState(); void updateState(bool isAdd = false);
void highlightSubShapes(); void highlightSubShapes();
void onGetInPlace(); void onGetInPlace();
void setInPlaceObj( GEOM::GEOM_Object_var, const bool isVisible=1); void setInPlaceObj( GEOM::GEOM_Object_var, const bool isVisible=1);
int getSelectedSubshapes (TColStd_IndexedMapOfInteger& theMapIndex);
private: private:
Mode myMode; Mode myMode;
@ -101,11 +105,14 @@ private:
QLineEdit* myMainName; QLineEdit* myMainName;
QPushButton* mySelBtn2; QPushButton* mySelBtn2;
QLineEdit* myShape2Name; QLineEdit* myShape2Name;
QGroupBox* mySelectionWayGroupBox; QGroupBox* myRestrictGroupBox;
QButtonGroup* mySelectionWayGroup; QButtonGroup* myRestrictGroup;
QPushButton* mySelAllBtn; QPushButton* mySelAllBtn;
QPushButton* myAddBtn; QPushButton* myAddBtn;
QPushButton* myRemBtn; QPushButton* myRemBtn;
QPushButton* myShowOnlyBtn;
QPushButton* myHideSelBtn;
QPushButton* myShowAllBtn;
QListWidget* myIdList; QListWidget* myIdList;
}; };