mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-12 01:30:36 +05:00
[bos #32774] [CEA 32488] Selecting multiple faces with "Supress Faces"
Update selection in Suppress Faces algorithm.
This commit is contained in:
parent
888b3b52e1
commit
db6a6a7fe5
@ -218,6 +218,7 @@ void RepairGUI_SuppressFacesDlg::SelectionIntoArgument()
|
|||||||
TopoDS_Shape aMainShape = GEOM_Client::get_client().GetShape(GeometryGUI::GetGeomGen(), myObject);
|
TopoDS_Shape aMainShape = GEOM_Client::get_client().GetShape(GeometryGUI::GetGeomGen(), myObject);
|
||||||
TopExp::MapShapes(aMainShape, aMainMap);
|
TopExp::MapShapes(aMainShape, aMainMap);
|
||||||
|
|
||||||
|
SALOME_ListIO aSelListToShow;
|
||||||
SALOME_ListIteratorOfListIO anIter (aSelList);
|
SALOME_ListIteratorOfListIO anIter (aSelList);
|
||||||
for (int i = 0; anIter.More(); anIter.Next(), i++) {
|
for (int i = 0; anIter.More(); anIter.Next(), i++) {
|
||||||
Handle(SALOME_InteractiveObject) anIO = anIter.Value();
|
Handle(SALOME_InteractiveObject) anIO = anIter.Value();
|
||||||
@ -231,17 +232,28 @@ void RepairGUI_SuppressFacesDlg::SelectionIntoArgument()
|
|||||||
if (GEOMBase::GetShape(aGeomObj, aShape)) {
|
if (GEOMBase::GetShape(aGeomObj, aShape)) {
|
||||||
if (aGeomObj->GetType() == GEOM_GROUP || aShape.ShapeType() == TopAbs_FACE) {
|
if (aGeomObj->GetType() == GEOM_GROUP || aShape.ShapeType() == TopAbs_FACE) {
|
||||||
TopExp_Explorer anExp (aShape, TopAbs_FACE);
|
TopExp_Explorer anExp (aShape, TopAbs_FACE);
|
||||||
|
bool isInside = false;
|
||||||
for (; anExp.More(); anExp.Next()) {
|
for (; anExp.More(); anExp.Next()) {
|
||||||
TopoDS_Shape aSubShape = anExp.Current();
|
TopoDS_Shape aSubShape = anExp.Current();
|
||||||
int anIndex = aMainMap.FindIndex(aSubShape);
|
int anIndex = aMainMap.FindIndex(aSubShape);
|
||||||
if (anIndex >= 0) {
|
if (anIndex > 0) {
|
||||||
aMap.Add(anIndex);
|
aMap.Add(anIndex);
|
||||||
anIds.Add(anIndex);
|
anIds.Add(anIndex);
|
||||||
|
isInside = true;
|
||||||
|
aSelListToShow.Append(anIO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!isInside)
|
||||||
|
{
|
||||||
|
disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0);
|
||||||
|
aSelMgr->AddOrRemoveIndex(anIO, anIds, false);
|
||||||
|
connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()),
|
||||||
|
this, SLOT(SelectionIntoArgument()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!aMap.IsEmpty()) {
|
if (!aMap.IsEmpty()) {
|
||||||
// highlight local faces, correspondent to OB selection
|
// highlight local faces, correspondent to OB selection
|
||||||
disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0);
|
disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0);
|
||||||
@ -255,6 +267,11 @@ void RepairGUI_SuppressFacesDlg::SelectionIntoArgument()
|
|||||||
|
|
||||||
aSelMgr->AddOrRemoveIndex(aSh->getIO(), anIds, false);
|
aSelMgr->AddOrRemoveIndex(aSh->getIO(), anIds, false);
|
||||||
|
|
||||||
|
SALOME_ListIteratorOfListIO anIter(aSelListToShow);
|
||||||
|
for (; anIter.More(); anIter.Next()) {
|
||||||
|
aSelMgr->AddOrRemoveIndex(anIter.Value(), anIds, false);
|
||||||
|
}
|
||||||
|
|
||||||
connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()),
|
connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()),
|
||||||
this, SLOT(SelectionIntoArgument()));
|
this, SLOT(SelectionIntoArgument()));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user