@ -45,23 +45,26 @@ namespace SceneUtil
virtual void apply ( osg : : Drawable & drawable )
{
std : : string lowerName = Misc : : StringUtils : : lowerCase ( drawable . getName ( ) ) ;
if ( ( lowerName . size ( ) > = mFilter . size ( ) & & lowerName . compare ( 0 , mFilter . size ( ) , mFilter ) = = 0 )
| | ( lowerName . size ( ) > = mFilter2 . size ( ) & & lowerName . compare ( 0 , mFilter2 . size ( ) , mFilter2 ) = = 0 ) )
{
if ( ! filterMatches ( drawable . getName ( ) ) )
return ;
osg : : Node * node = & drawable ;
while ( node & & node - > getNumParents ( ) & & ! node - > getStateSet ( ) )
node = node - > getParent ( 0 ) ;
if ( node )
mToCopy . push_back ( node ) ;
if ( ! node )
return ;
while ( node - > getNumParents ( ) )
{
osg : : Group * parent = node - > getParent ( 0 ) ;
if ( ! parent | | ! filterMatches ( parent - > getName ( ) ) )
break ;
node = parent ;
}
mToCopy . emplace ( node ) ;
}
void doCopy ( )
{
for ( std : : vector < osg : : ref_ptr < osg : : Node > > : : iterator it = mToCopy . begin ( ) ; it ! = mToCopy . end ( ) ; + + it )
for ( const osg : : ref_ptr < osg : : Node > & node : mToCopy )
{
osg : : ref_ptr < osg : : Node > node = * it ;
if ( node - > getNumParents ( ) > 1 )
Log ( Debug : : Error ) < < " Error CopyRigVisitor: node has multiple parents " ;
while ( node - > getNumParents ( ) )
@ -73,8 +76,16 @@ namespace SceneUtil
}
private :
typedef std : : vector < osg : : ref_ptr < osg : : Node > > NodeVector ;
NodeVector mToCopy ;
bool filterMatches ( const std : : string & name ) const
{
std : : string lowerName = Misc : : StringUtils : : lowerCase ( name ) ;
return ( lowerName . size ( ) > = mFilter . size ( ) & & lowerName . compare ( 0 , mFilter . size ( ) , mFilter ) = = 0 )
| | ( lowerName . size ( ) > = mFilter2 . size ( ) & & lowerName . compare ( 0 , mFilter2 . size ( ) , mFilter2 ) = = 0 ) ;
}
using NodeSet = std : : set < osg : : ref_ptr < osg : : Node > > ;
NodeSet mToCopy ;
osg : : ref_ptr < osg : : Group > mParent ;
std : : string mFilter ;