|
|
@ -302,8 +302,7 @@ namespace MWRender
|
|
|
|
|
|
|
|
|
|
|
|
bool forceShaders = mSceneManager->getForceShaders();
|
|
|
|
bool forceShaders = mSceneManager->getForceShaders();
|
|
|
|
|
|
|
|
|
|
|
|
mAtmosphereDay
|
|
|
|
mAtmosphereDay = mSceneManager->getInstance(Settings::models().mSkyatmosphere, mEarlyRenderBinRoot);
|
|
|
|
= mSceneManager->getInstance(Settings::Manager::getString("skyatmosphere", "Models"), mEarlyRenderBinRoot);
|
|
|
|
|
|
|
|
ModVertexAlphaVisitor modAtmosphere(ModVertexAlphaVisitor::Atmosphere);
|
|
|
|
ModVertexAlphaVisitor modAtmosphere(ModVertexAlphaVisitor::Atmosphere);
|
|
|
|
mAtmosphereDay->accept(modAtmosphere);
|
|
|
|
mAtmosphereDay->accept(modAtmosphere);
|
|
|
|
|
|
|
|
|
|
|
@ -315,12 +314,10 @@ namespace MWRender
|
|
|
|
mEarlyRenderBinRoot->addChild(mAtmosphereNightNode);
|
|
|
|
mEarlyRenderBinRoot->addChild(mAtmosphereNightNode);
|
|
|
|
|
|
|
|
|
|
|
|
osg::ref_ptr<osg::Node> atmosphereNight;
|
|
|
|
osg::ref_ptr<osg::Node> atmosphereNight;
|
|
|
|
if (mSceneManager->getVFS()->exists(Settings::Manager::getString("skynight02", "Models")))
|
|
|
|
if (mSceneManager->getVFS()->exists(Settings::models().mSkynight02.get()))
|
|
|
|
atmosphereNight = mSceneManager->getInstance(
|
|
|
|
atmosphereNight = mSceneManager->getInstance(Settings::models().mSkynight02, mAtmosphereNightNode);
|
|
|
|
Settings::Manager::getString("skynight02", "Models"), mAtmosphereNightNode);
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
atmosphereNight = mSceneManager->getInstance(
|
|
|
|
atmosphereNight = mSceneManager->getInstance(Settings::models().mSkynight01, mAtmosphereNightNode);
|
|
|
|
Settings::Manager::getString("skynight01", "Models"), mAtmosphereNightNode);
|
|
|
|
|
|
|
|
atmosphereNight->getOrCreateStateSet()->setAttributeAndModes(
|
|
|
|
atmosphereNight->getOrCreateStateSet()->setAttributeAndModes(
|
|
|
|
createAlphaTrackingUnlitMaterial(), osg::StateAttribute::ON | osg::StateAttribute::OVERRIDE);
|
|
|
|
createAlphaTrackingUnlitMaterial(), osg::StateAttribute::ON | osg::StateAttribute::OVERRIDE);
|
|
|
|
|
|
|
|
|
|
|
@ -340,8 +337,7 @@ namespace MWRender
|
|
|
|
mEarlyRenderBinRoot->addChild(mCloudNode);
|
|
|
|
mEarlyRenderBinRoot->addChild(mCloudNode);
|
|
|
|
|
|
|
|
|
|
|
|
mCloudMesh = new osg::PositionAttitudeTransform;
|
|
|
|
mCloudMesh = new osg::PositionAttitudeTransform;
|
|
|
|
osg::ref_ptr<osg::Node> cloudMeshChild
|
|
|
|
osg::ref_ptr<osg::Node> cloudMeshChild = mSceneManager->getInstance(Settings::models().mSkyclouds, mCloudMesh);
|
|
|
|
= mSceneManager->getInstance(Settings::Manager::getString("skyclouds", "Models"), mCloudMesh);
|
|
|
|
|
|
|
|
mCloudUpdater = new CloudUpdater(forceShaders);
|
|
|
|
mCloudUpdater = new CloudUpdater(forceShaders);
|
|
|
|
mCloudUpdater->setOpacity(1.f);
|
|
|
|
mCloudUpdater->setOpacity(1.f);
|
|
|
|
cloudMeshChild->addUpdateCallback(mCloudUpdater);
|
|
|
|
cloudMeshChild->addUpdateCallback(mCloudUpdater);
|
|
|
@ -349,7 +345,7 @@ namespace MWRender
|
|
|
|
|
|
|
|
|
|
|
|
mNextCloudMesh = new osg::PositionAttitudeTransform;
|
|
|
|
mNextCloudMesh = new osg::PositionAttitudeTransform;
|
|
|
|
osg::ref_ptr<osg::Node> nextCloudMeshChild
|
|
|
|
osg::ref_ptr<osg::Node> nextCloudMeshChild
|
|
|
|
= mSceneManager->getInstance(Settings::Manager::getString("skyclouds", "Models"), mNextCloudMesh);
|
|
|
|
= mSceneManager->getInstance(Settings::models().mSkyclouds, mNextCloudMesh);
|
|
|
|
mNextCloudUpdater = new CloudUpdater(forceShaders);
|
|
|
|
mNextCloudUpdater = new CloudUpdater(forceShaders);
|
|
|
|
mNextCloudUpdater->setOpacity(0.f);
|
|
|
|
mNextCloudUpdater->setOpacity(0.f);
|
|
|
|
nextCloudMeshChild->addUpdateCallback(mNextCloudUpdater);
|
|
|
|
nextCloudMeshChild->addUpdateCallback(mNextCloudUpdater);
|
|
|
@ -911,16 +907,16 @@ namespace MWRender
|
|
|
|
|
|
|
|
|
|
|
|
void SkyManager::listAssetsToPreload(std::vector<std::string>& models, std::vector<std::string>& textures)
|
|
|
|
void SkyManager::listAssetsToPreload(std::vector<std::string>& models, std::vector<std::string>& textures)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
models.emplace_back(Settings::Manager::getString("skyatmosphere", "Models"));
|
|
|
|
models.push_back(Settings::models().mSkyatmosphere);
|
|
|
|
if (mSceneManager->getVFS()->exists(Settings::Manager::getString("skynight02", "Models")))
|
|
|
|
if (mSceneManager->getVFS()->exists(Settings::models().mSkynight02.get()))
|
|
|
|
models.emplace_back(Settings::Manager::getString("skynight02", "Models"));
|
|
|
|
models.push_back(Settings::models().mSkynight02);
|
|
|
|
models.emplace_back(Settings::Manager::getString("skynight01", "Models"));
|
|
|
|
models.push_back(Settings::models().mSkynight01);
|
|
|
|
models.emplace_back(Settings::Manager::getString("skyclouds", "Models"));
|
|
|
|
models.push_back(Settings::models().mSkyclouds);
|
|
|
|
|
|
|
|
|
|
|
|
models.emplace_back(Settings::Manager::getString("weatherashcloud", "Models"));
|
|
|
|
models.push_back(Settings::models().mWeatherashcloud);
|
|
|
|
models.emplace_back(Settings::Manager::getString("weatherblightcloud", "Models"));
|
|
|
|
models.push_back(Settings::models().mWeatherblightcloud);
|
|
|
|
models.emplace_back(Settings::Manager::getString("weathersnow", "Models"));
|
|
|
|
models.push_back(Settings::models().mWeathersnow);
|
|
|
|
models.emplace_back(Settings::Manager::getString("weatherblizzard", "Models"));
|
|
|
|
models.push_back(Settings::models().mWeatherblizzard);
|
|
|
|
|
|
|
|
|
|
|
|
textures.emplace_back("textures/tx_mooncircle_full_s.dds");
|
|
|
|
textures.emplace_back("textures/tx_mooncircle_full_s.dds");
|
|
|
|
textures.emplace_back("textures/tx_mooncircle_full_m.dds");
|
|
|
|
textures.emplace_back("textures/tx_mooncircle_full_m.dds");
|
|
|
|