Fix: hardcoded weather meshes, use settings instead

Signed-off-by: Sam Hellawell <sshellawell@gmail.com>
fix-osga-rotate-wildly
Sam Hellawell 11 months ago
parent d168466034
commit af8c2a94df

@ -2,6 +2,7 @@
#include <components/misc/rng.hpp> #include <components/misc/rng.hpp>
#include <components/settings/values.hpp>
#include <components/esm3/esmreader.hpp> #include <components/esm3/esmreader.hpp>
#include <components/esm3/esmwriter.hpp> #include <components/esm3/esmwriter.hpp>
#include <components/esm3/loadregn.hpp> #include <components/esm3/loadregn.hpp>
@ -45,7 +46,7 @@ namespace MWWorld
osg::Vec3f calculateStormDirection(const std::string& particleEffect) osg::Vec3f calculateStormDirection(const std::string& particleEffect)
{ {
osg::Vec3f stormDirection = MWWorld::Weather::defaultDirection(); osg::Vec3f stormDirection = MWWorld::Weather::defaultDirection();
if (particleEffect == "meshes\\ashcloud.nif" || particleEffect == "meshes\\blightcloud.nif") if (particleEffect == Settings::models().mWeatherashcloud.get() || particleEffect == Settings::models().mWeatherblightcloud.get())
{ {
osg::Vec3f playerPos = MWMechanics::getPlayer().getRefData().getPosition().asVec3(); osg::Vec3f playerPos = MWMechanics::getPlayer().getRefData().getPosition().asVec3();
playerPos.z() = 0; playerPos.z() = 0;
@ -581,10 +582,10 @@ namespace MWWorld
addWeather("Overcast", 0.7f, 0.0f); // 3 addWeather("Overcast", 0.7f, 0.0f); // 3
addWeather("Rain", 0.5f, 10.0f); // 4 addWeather("Rain", 0.5f, 10.0f); // 4
addWeather("Thunderstorm", 0.5f, 20.0f); // 5 addWeather("Thunderstorm", 0.5f, 20.0f); // 5
addWeather("Ashstorm", 0.2f, 50.0f, "meshes\\ashcloud.nif"); // 6 addWeather("Ashstorm", 0.2f, 50.0f, Settings::models().mWeatherashcloud.get()); // 6
addWeather("Blight", 0.2f, 60.0f, "meshes\\blightcloud.nif"); // 7 addWeather("Blight", 0.2f, 60.0f, Settings::models().mWeatherblightcloud.get()); // 7
addWeather("Snow", 0.5f, 40.0f, "meshes\\snow.nif"); // 8 addWeather("Snow", 0.5f, 40.0f, Settings::models().mWeathersnow.get()); // 8
addWeather("Blizzard", 0.16f, 70.0f, "meshes\\blizzard.nif"); // 9 addWeather("Blizzard", 0.16f, 70.0f, Settings::models().mWeatherblizzard.get()); // 9
Store<ESM::Region>::iterator it = store.get<ESM::Region>().begin(); Store<ESM::Region>::iterator it = store.get<ESM::Region>().begin();
for (; it != store.get<ESM::Region>().end(); ++it) for (; it != store.get<ESM::Region>().end(); ++it)
@ -720,7 +721,7 @@ namespace MWWorld
// For some reason Ash Storm is not considered as a precipitation weather in game // For some reason Ash Storm is not considered as a precipitation weather in game
mPrecipitation = !(mResult.mParticleEffect.empty() && mResult.mRainEffect.empty()) mPrecipitation = !(mResult.mParticleEffect.empty() && mResult.mRainEffect.empty())
&& mResult.mParticleEffect != "meshes\\ashcloud.nif"; && mResult.mParticleEffect != Settings::models().mWeatherashcloud.get();
mStormDirection = calculateStormDirection(mResult.mParticleEffect); mStormDirection = calculateStormDirection(mResult.mParticleEffect);
mRendering.getSkyManager()->setStormParticleDirection(mStormDirection); mRendering.getSkyManager()->setStormParticleDirection(mStormDirection);

Loading…
Cancel
Save