@ -703,7 +703,10 @@ namespace SceneUtil
{
{
public :
public :
LightManagerStateAttribute ( )
LightManagerStateAttribute ( )
: mLightManager ( nullptr ) { }
: mLightManager ( nullptr )
, mInitLayout ( false )
{
}
LightManagerStateAttribute ( LightManager * lightManager )
LightManagerStateAttribute ( LightManager * lightManager )
: mLightManager ( lightManager )
: mLightManager ( lightManager )
@ -720,7 +723,7 @@ namespace SceneUtil
}
}
LightManagerStateAttribute ( const LightManagerStateAttribute & copy , const osg : : CopyOp & copyop = osg : : CopyOp : : SHALLOW_COPY )
LightManagerStateAttribute ( const LightManagerStateAttribute & copy , const osg : : CopyOp & copyop = osg : : CopyOp : : SHALLOW_COPY )
: osg : : StateAttribute ( copy , copyop ) , mLightManager ( copy . mLightManager ) { }
: osg : : StateAttribute ( copy , copyop ) , mLightManager ( copy . mLightManager ) , mInitLayout ( copy . mInitLayout ) { }
int compare ( const StateAttribute & sa ) const override
int compare ( const StateAttribute & sa ) const override
{
{
@ -874,7 +877,7 @@ namespace SceneUtil
hasLoggedWarnings = true ;
hasLoggedWarnings = true ;
}
}
int targetLights = Settings: : Manager : : getInt ( " max lights " , " Shaders " ) ;
int targetLights = std: : clamp ( Settings: : Manager : : getInt ( " max lights " , " Shaders " ) , mMaxLightsLowerLimit , mMaxLightsUpperLimit ) ;
if ( ! supportsUBO | | ! supportsGPU4 | | lightingMethod = = LightingMethod : : PerObjectUniform )
if ( ! supportsUBO | | ! supportsGPU4 | | lightingMethod = = LightingMethod : : PerObjectUniform )
initPerObjectUniform ( targetLights ) ;
initPerObjectUniform ( targetLights ) ;
@ -954,7 +957,8 @@ namespace SceneUtil
if ( usingFFP ( ) )
if ( usingFFP ( ) )
return ;
return ;
setMaxLights ( std : : clamp ( Settings : : Manager : : getInt ( " max lights " , " Shaders " ) , mMaxLightsLowerLimit , mMaxLightsUpperLimit ) ) ;
int targetLights = std : : clamp ( Settings : : Manager : : getInt ( " max lights " , " Shaders " ) , mMaxLightsLowerLimit , mMaxLightsUpperLimit ) ;
setMaxLights ( targetLights ) ;
if ( getLightingMethod ( ) = = LightingMethod : : PerObjectUniform )
if ( getLightingMethod ( ) = = LightingMethod : : PerObjectUniform )
{
{
@ -1033,7 +1037,7 @@ namespace SceneUtil
auto * stateset = getOrCreateStateSet ( ) ;
auto * stateset = getOrCreateStateSet ( ) ;
setLightingMethod ( LightingMethod : : PerObjectUniform ) ;
setLightingMethod ( LightingMethod : : PerObjectUniform ) ;
setMaxLights ( std: : clamp ( targetLights, mMaxLightsLowerLimit , mMaxLightsUpperLimit ) ) ;
setMaxLights ( targetLights) ;
// ensures sunlight element in our uniform array is updated when there are no point lights in scene
// ensures sunlight element in our uniform array is updated when there are no point lights in scene
stateset - > setAttributeAndModes ( new LightStateAttributePerObjectUniform ( { } , this ) , osg : : StateAttribute : : ON ) ;
stateset - > setAttributeAndModes ( new LightStateAttributePerObjectUniform ( { } , this ) , osg : : StateAttribute : : ON ) ;
@ -1043,7 +1047,7 @@ namespace SceneUtil
void LightManager : : initSingleUBO ( int targetLights )
void LightManager : : initSingleUBO ( int targetLights )
{
{
setLightingMethod ( LightingMethod : : SingleUBO ) ;
setLightingMethod ( LightingMethod : : SingleUBO ) ;
setMaxLights ( std: : clamp ( targetLights, mMaxLightsLowerLimit , mMaxLightsUpperLimit ) ) ;
setMaxLights ( targetLights) ;
for ( int i = 0 ; i < 2 ; + + i )
for ( int i = 0 ; i < 2 ; + + i )
{
{