|
|
@ -195,6 +195,7 @@ namespace MWRender
|
|
|
|
, mWorkQueue(workQueue)
|
|
|
|
, mWorkQueue(workQueue)
|
|
|
|
, mUnrefQueue(new SceneUtil::UnrefQueue)
|
|
|
|
, mUnrefQueue(new SceneUtil::UnrefQueue)
|
|
|
|
, mNavigator(navigator)
|
|
|
|
, mNavigator(navigator)
|
|
|
|
|
|
|
|
, mMinimumAmbientLuminance(0.f)
|
|
|
|
, mNightEyeFactor(0.f)
|
|
|
|
, mNightEyeFactor(0.f)
|
|
|
|
, mFieldOfViewOverridden(false)
|
|
|
|
, mFieldOfViewOverridden(false)
|
|
|
|
, mFieldOfViewOverride(0.f)
|
|
|
|
, mFieldOfViewOverride(0.f)
|
|
|
@ -223,6 +224,9 @@ namespace MWRender
|
|
|
|
resourceSystem->getSceneManager()->getShaderManager().setLightingMethod(sceneRoot->getLightingMethod());
|
|
|
|
resourceSystem->getSceneManager()->getShaderManager().setLightingMethod(sceneRoot->getLightingMethod());
|
|
|
|
resourceSystem->getSceneManager()->setLightingMethod(sceneRoot->getLightingMethod());
|
|
|
|
resourceSystem->getSceneManager()->setLightingMethod(sceneRoot->getLightingMethod());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (sceneRoot->getLightingMethod() != SceneUtil::LightingMethod::FFP)
|
|
|
|
|
|
|
|
mMinimumAmbientLuminance = std::clamp(Settings::Manager::getFloat("minimum interior brightness", "Shaders"), 0.f, 1.f);
|
|
|
|
|
|
|
|
|
|
|
|
sceneRoot->setLightingMask(Mask_Lighting);
|
|
|
|
sceneRoot->setLightingMask(Mask_Lighting);
|
|
|
|
mSceneRoot = sceneRoot;
|
|
|
|
mSceneRoot = sceneRoot;
|
|
|
|
sceneRoot->setStartLight(1);
|
|
|
|
sceneRoot->setStartLight(1);
|
|
|
@ -1072,7 +1076,25 @@ namespace MWRender
|
|
|
|
osg::Vec4f color = mAmbientColor;
|
|
|
|
osg::Vec4f color = mAmbientColor;
|
|
|
|
|
|
|
|
|
|
|
|
if (mNightEyeFactor > 0.f)
|
|
|
|
if (mNightEyeFactor > 0.f)
|
|
|
|
|
|
|
|
{
|
|
|
|
color += osg::Vec4f(0.7, 0.7, 0.7, 0.0) * mNightEyeFactor;
|
|
|
|
color += osg::Vec4f(0.7, 0.7, 0.7, 0.0) * mNightEyeFactor;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// optionally brighten up ambient interiors when using a non-FFP emulated lighting method
|
|
|
|
|
|
|
|
else if (mResourceSystem->getSceneManager()->getLightingMethod() != SceneUtil::LightingMethod::FFP)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
static constexpr float pR = 0.2126;
|
|
|
|
|
|
|
|
static constexpr float pG = 0.7152;
|
|
|
|
|
|
|
|
static constexpr float pB = 0.0722;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// we already work in linear RGB so no conversions are needed for the luminosity function
|
|
|
|
|
|
|
|
float relativeLuminance = pR*color.r() + pG*color.g() + pB*color.b();
|
|
|
|
|
|
|
|
if (relativeLuminance < mMinimumAmbientLuminance)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// brighten ambient so it reaches the minimum threshold but no more, we want to mess with content data as least we can
|
|
|
|
|
|
|
|
float targetBrightnessIncreaseFactor = mMinimumAmbientLuminance / relativeLuminance;
|
|
|
|
|
|
|
|
color *= targetBrightnessIncreaseFactor;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
mStateUpdater->setAmbientColor(color);
|
|
|
|
mStateUpdater->setAmbientColor(color);
|
|
|
|
}
|
|
|
|
}
|
|
|
|