for( int anIndex = 0, aNbRef = theImage->NbReferences(); anIndex < aNbRef; anIndex++ )
{
- Handle(HYDROData_Image) aRefImage = theImage->Reference( anIndex );
- if( !aRefImage.IsNull() && !aRefImage->IsRemoved() )
+ Handle(HYDROData_Object) aRefObj = theImage->Reference( anIndex );
+ if( !aRefObj.IsNull() && !aRefObj->IsRemoved() )
{
- QString aName = aRefImage->GetName();
+ QString aName = aRefObj->GetName();
if( !theRefNames.contains( aName ) )
{
- theRefObjects.Append( aRefImage );
- theRefNames.append( aRefImage->GetName() );
- GetObjectReferences( aRefImage, theRefObjects, theRefNames );
+ theRefObjects.Append( aRefObj );
+ theRefNames.append( aRefObj->GetName() );
+ if( aRefObj->GetKind() == KIND_IMAGE )
+ {
+ Handle(HYDROData_Image) aRefImage = Handle(HYDROData_Image)::DownCast( aRefObj );
+ if( !aRefImage.IsNull() )
+ GetObjectReferences( aRefImage, theRefObjects, theRefNames );
+ }
}
}
}