Read Ambient Loop Sound ID and Rain Loop Sound ID from the INI file

openmw-38
scrawl 9 years ago
parent e9e12d396d
commit 71d9e7dc52

@ -103,7 +103,6 @@ Weather::Weather(const std::string& name,
const MWWorld::Fallback& fallback, const MWWorld::Fallback& fallback,
float stormWindSpeed, float stormWindSpeed,
float rainSpeed, float rainSpeed,
const std::string& ambientLoopSoundID,
const std::string& particleEffect) const std::string& particleEffect)
: mCloudTexture(fallback.getFallbackString("Weather_" + name + "_Cloud_Texture")) : mCloudTexture(fallback.getFallbackString("Weather_" + name + "_Cloud_Texture"))
, mSkyColor(fallback.getFallbackColour("Weather_" + name +"_Sky_Sunrise_Color"), , mSkyColor(fallback.getFallbackColour("Weather_" + name +"_Sky_Sunrise_Color"),
@ -130,7 +129,6 @@ Weather::Weather(const std::string& name,
, mWindSpeed(fallback.getFallbackFloat("Weather_" + name + "_Wind_Speed")) , mWindSpeed(fallback.getFallbackFloat("Weather_" + name + "_Wind_Speed"))
, mCloudSpeed(fallback.getFallbackFloat("Weather_" + name + "_Cloud_Speed")) , mCloudSpeed(fallback.getFallbackFloat("Weather_" + name + "_Cloud_Speed"))
, mGlareView(fallback.getFallbackFloat("Weather_" + name + "_Glare_View")) , mGlareView(fallback.getFallbackFloat("Weather_" + name + "_Glare_View"))
, mAmbientLoopSoundID(ambientLoopSoundID)
, mIsStorm(mWindSpeed > stormWindSpeed) , mIsStorm(mWindSpeed > stormWindSpeed)
, mRainSpeed(rainSpeed) , mRainSpeed(rainSpeed)
, mRainFrequency(fallback.getFallbackFloat("Weather_" + name + "_Rain_Entrance_Speed")) , mRainFrequency(fallback.getFallbackFloat("Weather_" + name + "_Rain_Entrance_Speed"))
@ -148,6 +146,18 @@ Weather::Weather(const std::string& name,
mThunderSoundID[1] = fallback.getFallbackString("Weather_" + name + "_Thunder_Sound_ID_1"); mThunderSoundID[1] = fallback.getFallbackString("Weather_" + name + "_Thunder_Sound_ID_1");
mThunderSoundID[2] = fallback.getFallbackString("Weather_" + name + "_Thunder_Sound_ID_2"); mThunderSoundID[2] = fallback.getFallbackString("Weather_" + name + "_Thunder_Sound_ID_2");
mThunderSoundID[3] = fallback.getFallbackString("Weather_" + name + "_Thunder_Sound_ID_3"); mThunderSoundID[3] = fallback.getFallbackString("Weather_" + name + "_Thunder_Sound_ID_3");
// TODO: support weathers that have both "Ambient Loop Sound ID" and "Rain Loop Sound ID", need to play both sounds at the same time.
if (!mRainEffect.empty()) // NOTE: in vanilla, the weathers with rain seem to be hardcoded; changing Using_Precip has no effect
{
mAmbientLoopSoundID = fallback.getFallbackString("Weather_" + name + "_Rain_Loop_Sound_ID");
if (mAmbientLoopSoundID.empty()) // default to "rain" if not set
mAmbientLoopSoundID = "rain";
}
else
mAmbientLoopSoundID = fallback.getFallbackString("Weather_" + name + "_Ambient_Loop_Sound_ID");
/* /*
Unhandled: Unhandled:
Rain Diameter=600 ? Rain Diameter=600 ?
@ -528,12 +538,12 @@ WeatherManager::WeatherManager(MWRender::RenderingManager& rendering, const MWWo
addWeather("Cloudy", fallback); // 1 addWeather("Cloudy", fallback); // 1
addWeather("Foggy", fallback); // 2 addWeather("Foggy", fallback); // 2
addWeather("Overcast", fallback); // 3 addWeather("Overcast", fallback); // 3
addWeather("Rain", fallback, "rain"); // 4 addWeather("Rain", fallback); // 4
addWeather("Thunderstorm", fallback, "rain heavy"); // 5 addWeather("Thunderstorm", fallback); // 5
addWeather("Ashstorm", fallback, "ashstorm", "meshes\\ashcloud.nif"); // 6 addWeather("Ashstorm", fallback, "meshes\\ashcloud.nif"); // 6
addWeather("Blight", fallback, "blight", "meshes\\blightcloud.nif"); // 7 addWeather("Blight", fallback, "meshes\\blightcloud.nif"); // 7
addWeather("Snow", fallback, "", "meshes\\snow.nif"); // 8 addWeather("Snow", fallback, "meshes\\snow.nif"); // 8
addWeather("Blizzard", fallback, "BM Blizzard", "meshes\\blizzard.nif"); // 9 addWeather("Blizzard", fallback, "meshes\\blizzard.nif"); // 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)
@ -852,12 +862,11 @@ void WeatherManager::clear()
inline void WeatherManager::addWeather(const std::string& name, inline void WeatherManager::addWeather(const std::string& name,
const MWWorld::Fallback& fallback, const MWWorld::Fallback& fallback,
const std::string& ambientLoopSoundID,
const std::string& particleEffect) const std::string& particleEffect)
{ {
static const float fStromWindSpeed = mStore.get<ESM::GameSetting>().find("fStromWindSpeed")->getFloat(); static const float fStromWindSpeed = mStore.get<ESM::GameSetting>().find("fStromWindSpeed")->getFloat();
Weather weather(name, fallback, fStromWindSpeed, mRainSpeed, ambientLoopSoundID, particleEffect); Weather weather(name, fallback, fStromWindSpeed, mRainSpeed, particleEffect);
mWeatherSettings.push_back(weather); mWeatherSettings.push_back(weather);
} }

@ -69,7 +69,6 @@ namespace MWWorld
const MWWorld::Fallback& fallback, const MWWorld::Fallback& fallback,
float stormWindSpeed, float stormWindSpeed,
float rainSpeed, float rainSpeed,
const std::string& ambientLoopSoundID,
const std::string& particleEffect); const std::string& particleEffect);
std::string mCloudTexture; std::string mCloudTexture;
@ -290,7 +289,6 @@ namespace MWWorld
void addWeather(const std::string& name, void addWeather(const std::string& name,
const MWWorld::Fallback& fallback, const MWWorld::Fallback& fallback,
const std::string& ambientLoopSoundID = "",
const std::string& particleEffect = ""); const std::string& particleEffect = "");
void importRegions(); void importRegions();

Loading…
Cancel
Save