mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-22 15:10:34 +05:00
260 lines
7.9 KiB
C++
260 lines
7.9 KiB
C++
|
#include "GEOMGUI_OCCSelector.h"
|
||
|
|
||
|
#include <SalomeApp_DataSubOwner.h>
|
||
|
|
||
|
#include <OCCViewer_ViewModel.h>
|
||
|
|
||
|
#include <SALOME_InteractiveObject.hxx>
|
||
|
|
||
|
#include <AIS_ListOfInteractive.hxx>
|
||
|
#include <AIS_ListIteratorOfListOfInteractive.hxx>
|
||
|
#include <SelectMgr_EntityOwner.hxx>
|
||
|
#include <AIS_Shape.hxx>
|
||
|
#include <TopTools_IndexedMapOfShape.hxx>
|
||
|
#include <TopExp.hxx>
|
||
|
#include <SelectMgr_IndexedMapOfOwner.hxx>
|
||
|
#include <TColStd_ListIteratorOfListOfInteger.hxx>
|
||
|
#include <SelectMgr_Selection.hxx>
|
||
|
#include <SelectBasics_SensitiveEntity.hxx>
|
||
|
#include <TColStd_IndexedMapOfInteger.hxx>
|
||
|
#include <SelectMgr_IndexedMapOfOwner.hxx>
|
||
|
#include <NCollection_DataMap.hxx>
|
||
|
|
||
|
|
||
|
//================================================================
|
||
|
// 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<TCollection_AsciiString, TColStd_IndexedMapOfInteger> indexesMap; // "entry - list_of_int" map for LOCAL selection
|
||
|
QMap<QString,int> 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<const SalomeApp_DataSubOwner*>( (*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<const SalomeApp_DataOwner*>( (*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();
|
||
|
}
|