@ -56,18 +56,6 @@ namespace SceneUtil
}
}
state . applyModelViewMatrix ( modelViewMatrix ) ;
state . applyModelViewMatrix ( modelViewMatrix ) ;
/*
for ( int i = 0 ; i < 8 ; + + i )
{
osg : : ref_ptr < osg : : Light > defaultLight ( new osg : : Light ( i ) ) ;
defaultLight - > setAmbient ( osg : : Vec4 ( ) ) ;
defaultLight - > setDiffuse ( osg : : Vec4 ( ) ) ;
defaultLight - > setSpecular ( osg : : Vec4 ( ) ) ;
defaultLight - > setConstantAttenuation ( 0.f ) ;
state . setGlobalDefaultAttribute ( defaultLight ) ;
}
*/
}
}
private :
private :
@ -204,19 +192,19 @@ namespace SceneUtil
return found - > second ;
return found - > second ;
else
else
{
{
osg : : ref_ptr < osg : : StateSet > stateset = new osg : : StateSet ;
std : : vector < osg : : ref_ptr < osg : : Light > > lights ;
for ( unsigned int i = 0 ; i < lightList . size ( ) ; + + i )
for ( unsigned int i = 0 ; i < lightList . size ( ) ; + + i )
{
std : : vector < osg : : ref_ptr < osg : : Light > > lights ;
lights . push_back ( lightList [ i ] - > mLightSource - > getLight ( frameNum ) ) ;
lights . push_back ( lightList [ i ] - > mLightSource - > getLight ( frameNum ) ) ;
osg : : ref_ptr < LightStateAttribute > attr = new LightStateAttribute ( mStartLight + i , lights ) ;
osg : : ref_ptr < LightStateAttribute > attr = new LightStateAttribute ( mStartLight , lights ) ;
osg : : ref_ptr < osg : : StateSet > stateset = new osg : : StateSet ;
// don't use setAttributeAndModes, that does not support light indices!
// don't use setAttributeAndModes, that does not support light indices!
stateset - > setAttribute ( attr , osg : : StateAttribute : : ON ) ;
stateset - > setAttribute ( attr , osg : : StateAttribute : : ON ) ;
stateset - > setAssociatedModes ( attr , osg : : StateAttribute : : ON ) ;
stateset - > setAssociatedModes ( attr , osg : : StateAttribute : : ON ) ;
}
stateSetCache . insert ( std : : make_pair ( hash , stateset ) ) ;
stateSetCache . insert ( std : : make_pair ( hash , stateset ) ) ;
return stateset ;
return stateset ;
}
}
@ -254,6 +242,17 @@ namespace SceneUtil
void LightManager : : setStartLight ( int start )
void LightManager : : setStartLight ( int start )
{
{
mStartLight = start ;
mStartLight = start ;
// Set default light state to zero
for ( int i = start ; i < 8 ; + + i )
{
osg : : ref_ptr < osg : : Light > defaultLight ( new osg : : Light ( i ) ) ;
defaultLight - > setAmbient ( osg : : Vec4 ( ) ) ;
defaultLight - > setDiffuse ( osg : : Vec4 ( ) ) ;
defaultLight - > setSpecular ( osg : : Vec4 ( ) ) ;
defaultLight - > setConstantAttenuation ( 0.f ) ;
getOrCreateStateSet ( ) - > setAttributeAndModes ( defaultLight , osg : : StateAttribute : : OFF ) ;
}
}
}
int LightManager : : getStartLight ( ) const
int LightManager : : getStartLight ( ) const