#include "GEOMGUI_OCCSelector.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include //================================================================ // Function : GEOMGUI_OCCSelector // Purpose : //================================================================ GEOMGUI_OCCSelector::GEOMGUI_OCCSelector( OCCViewer_Viewer* viewer, SUIT_SelectionMgr* mgr ) : SalomeApp_OCCSelector( viewer, mgr ) { } //================================================================ // Function : ~GEOMGUI_OCCSelector // Purpose : //================================================================ GEOMGUI_OCCSelector::~GEOMGUI_OCCSelector() { } //================================================================ // Function : getSelection // Purpose : //================================================================ void GEOMGUI_OCCSelector::getSelection( SUIT_DataOwnerPtrList& aList ) const { OCCViewer_Viewer* vw = viewer(); if ( !vw ) return; Handle(AIS_InteractiveContext) ic = vw->getAISContext(); if ( ic->HasOpenedContext() ) { for ( ic->InitSelected(); ic->MoreSelected(); ic->NextSelected() ) { Handle(SelectMgr_EntityOwner) anOwner = ic->SelectedOwner(); if ( anOwner.IsNull() ) continue; Handle(AIS_InteractiveObject) io = Handle(AIS_InteractiveObject)::DownCast( anOwner->Selectable() ); QString entryStr = entry( io ); int index = -1; if ( anOwner->ComesFromDecomposition() ) // == Local Selection { TopoDS_Shape subShape = anOwner->Shape(); Handle(AIS_Shape) aisShape = Handle(AIS_Shape)::DownCast( io ); if ( !aisShape.IsNull() ) { TopoDS_Shape bigShape = aisShape->Shape(); TopTools_IndexedMapOfShape subShapes; TopExp::MapShapes( bigShape, subShapes ); index = subShapes.FindIndex( subShape ); } } if ( !entryStr.isEmpty() ) { SalomeApp_DataOwner* owner; if ( index > -1 ) // Local Selection owner = new SalomeApp_DataSubOwner( entryStr, index ); else // Global Selection owner = new SalomeApp_DataOwner( entryStr ); aList.append( SUIT_DataOwnerPtr( owner ) ); } } } else { for ( ic->InitCurrent(); ic->MoreCurrent(); ic->NextCurrent() ) { Handle(AIS_InteractiveObject) io = ic->Current(); QString entryStr = entry( io ); if ( !entryStr.isEmpty() ) { SalomeApp_DataOwner* owner = new SalomeApp_DataOwner( entryStr ); aList.append( SUIT_DataOwnerPtr( owner ) ); } } } } //================================================================ // Function : getEntityOwners // Purpose : //================================================================ static void getEntityOwners( const Handle(AIS_InteractiveObject)& theObj, const Handle(AIS_InteractiveContext)& theIC, SelectMgr_IndexedMapOfOwner& theMap ) { if ( theObj.IsNull() || theIC.IsNull() ) return; TColStd_ListOfInteger modes; theIC->ActivatedModes( theObj, modes ); TColStd_ListIteratorOfListOfInteger itr( modes ); for (; itr.More(); itr.Next() ) { int m = itr.Value(); if ( !theObj->HasSelection( m ) ) continue; Handle(SelectMgr_Selection) sel = theObj->Selection( m ); for ( sel->Init(); sel->More(); sel->Next() ) { Handle(SelectBasics_SensitiveEntity) entity = sel->Sensitive(); if ( entity.IsNull() ) continue; Handle(SelectMgr_EntityOwner) owner = Handle(SelectMgr_EntityOwner)::DownCast(entity->OwnerId()); if ( !owner.IsNull() ) theMap.Add( owner ); } } } //================================================================ // Function : setSelection // Purpose : //================================================================ void GEOMGUI_OCCSelector::setSelection( const SUIT_DataOwnerPtrList& aList ) { OCCViewer_Viewer* vw = viewer(); if ( !vw ) return; Handle(AIS_InteractiveContext) ic = vw->getAISContext(); NCollection_DataMap indexesMap; // "entry - list_of_int" map for LOCAL selection QMap globalSelMap; // only Key=entry from this map is used. value(int) is NOT used at all. SelectMgr_IndexedMapOfOwner ownersmap; // map of owners to be selected AIS_ListOfInteractive aDispList; ic->DisplayedObjects( aDispList ); // build a map of data owner indexes to be selected. // "entry - to - list_of_ids" map for ( SUIT_DataOwnerPtrList::const_iterator itr = aList.begin(); itr != aList.end(); ++itr ) { const SalomeApp_DataSubOwner* subOwner = dynamic_cast( (*itr).operator->() ); if ( subOwner ) { QString entry = subOwner->entry(); if ( indexesMap.IsBound( TCollection_AsciiString((char*)entry.latin1()))) { TColStd_IndexedMapOfInteger& subIndexes = indexesMap.ChangeFind((char*)entry.latin1()); subIndexes.Add( subOwner->index() ); //indexesMap.replace( entry, subIndexes ); } else { TColStd_IndexedMapOfInteger subIndexes; subIndexes.Add( subOwner->index() ); indexesMap.Bind((char*)entry.latin1(), subIndexes); } } else // the owner is NOT a sub owner, maybe it is a DataOwner == GLOBAL selection { const SalomeApp_DataOwner* owner = dynamic_cast( (*itr).operator->() ); if ( owner ) { globalSelMap[owner->entry()] = 1; } } } // get all owners. Fill "entry - list_of_owners" map. for ( AIS_ListIteratorOfListOfInteractive it( aDispList ); it.More(); it.Next() ) { Handle(AIS_InteractiveObject) io = it.Value(); QString entryStr = entry( io ); if ( !entryStr.isEmpty() ) { //EntryToListOfOwnerMap entryOwnersMap; // "entry - list_of_owners" map. temporary use. SelectMgr_IndexedMapOfOwner owners; getEntityOwners( io, ic, owners ); // get all owners for ( int i = 1, n = owners.Extent(); i <= n; i++ ) { Handle(SelectMgr_EntityOwner) anOwner = owners( i ); if ( anOwner.IsNull() || !anOwner->HasShape() ) continue; // GLOBAL selection if ( !anOwner->ComesFromDecomposition() && globalSelMap.contains( entryStr ) ) { ownersmap.Add( anOwner ); } // LOCAL selection else { Handle(AIS_Shape) aisShape = Handle(AIS_Shape)::DownCast( io ); if ( !aisShape.IsNull() && indexesMap.IsBound( (char*)entryStr.latin1() ) ) { TopoDS_Shape shape = aisShape->Shape(); TopTools_IndexedMapOfShape aMapOfShapes; TopExp::MapShapes( shape, aMapOfShapes ); const TColStd_IndexedMapOfInteger& subIndexes = indexesMap.ChangeFind((char*)entryStr.latin1()); const TopoDS_Shape& aSubShape = anOwner->Shape(); int aSubShapeId = aMapOfShapes.FindIndex( aSubShape ); // check if the "sub_shape_index" is found in the "map of indexes for this entry", // which was passes in the parameter if ( subIndexes.Contains( aSubShapeId ) ) { ownersmap.Add( anOwner ); } } } // end of local selection } // end of for(owners) }// end of if(entry) }// end of for(AIS_all_ios) vw->unHighlightAll( false ); // DO the selection for ( int i = 1, n = ownersmap.Extent(); i <= n; i++ ) { Handle(SelectMgr_EntityOwner) owner = ownersmap( i ); if ( owner->State() ) continue; if ( ic->HasOpenedContext() ) ic->AddOrRemoveSelected( owner, false ); else ic->AddOrRemoveSelected( Handle(AIS_InteractiveObject)::DownCast(owner->Selectable()), false ); } vw->update(); }