#include "HYDROGUI_DataObject.h"
#include "HYDROGUI_DataOwner.h"
#include "HYDROGUI_Module.h"
+#include "HYDROGUI_Shape.h"
#include <AIS_ListOfInteractive.hxx>
#include <AIS_ListIteratorOfListOfInteractive.hxx>
if ( !aViewer )
return;
+ int aViewerId = (size_t)aViewer;
+
Handle(AIS_InteractiveContext) aContext = aViewer->getAISContext();
if ( aContext.IsNull() || aContext->HasOpenedContext() ) {
return;
}
- QMap<QString, Handle(AIS_InteractiveObject)> aDisplayed;
- AIS_ListOfInteractive aDispList, aSelList;
+ AIS_ListOfInteractive aSelList;
+
+ /*QMap<QString, Handle(AIS_InteractiveObject)> aDisplayed;
+ AIS_ListOfInteractive aDispList;
aContext->DisplayedObjects( aDispList );
for ( AIS_ListIteratorOfListOfInteractive it( aDispList ); it.More(); it.Next() )
QString entryStr = entry( it.Value() );
if ( !entryStr.isEmpty() )
aDisplayed.insert( entryStr, it.Value() );
- }
+ }*/
mySelectedExternals.clear();
for ( SUIT_DataOwnerPtrList::const_iterator itr = aList.begin(); itr != aList.end(); ++itr )
{
const LightApp_DataOwner* owner = dynamic_cast<const LightApp_DataOwner*>( (*itr).operator->() );
- if ( owner && aDisplayed.contains( owner->entry() ) )
- aSelList.Append( aDisplayed[owner->entry()] );
+ if ( owner ) //&& aDisplayed.contains( owner->entry() ) )
+ {
+ QString anEntry = owner->entry();
+ Handle(HYDROData_Entity) anEntity = myModule->getDataModel()->objectByEntry( anEntry );
+ if( !anEntity.IsNull() )
+ {
+ HYDROGUI_Shape* aShape = myModule->getObjectShape( aViewerId, anEntity );
+ if( aShape && aShape->isVisible() )
+ {
+ foreach( Handle(AIS_InteractiveObject) obj, aShape->getAISObjects() )
+ aSelList.Append( obj );
+ }
+ }
+ }
else {
const HYDROGUI_DataOwner* hydroOwner = dynamic_cast<const HYDROGUI_DataOwner*>( (*itr).operator->() );
if ( hydroOwner && !hydroOwner->IO().IsNull() ) {
aRes = HYDROGUI_DataObject::dataObjectEntry( anObj );
return aRes;
-}
\ No newline at end of file
+}