1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-27 12:35:46 +00:00

Simpler statistical calculation of next weather; minus before parens.

This commit is contained in:
Miroslav Puda 2013-06-19 04:57:36 +02:00
parent 04d90b4c47
commit f01aa8f55e

View File

@ -375,42 +375,36 @@ void WeatherManager::update(float duration)
if (region != 0) if (region != 0)
{ {
float clear = region->mData.mClear/255.f; /*
float cloudy = region->mData.mCloudy/255.f; * All probabilities must add to 100 (responsibility of the user).
float foggy = region->mData.mFoggy/255.f; * If chances A and B has values 30 and 70 then by generating
float overcast = region->mData.mOvercast/255.f; * 100 numbers 1..100, 30% will be lesser or equal 30 and
float rain = region->mData.mRain/255.f; * 70% will be greater than 30 (in theory).
float thunder = region->mData.mThunder/255.f; */
float ash = region->mData.mAsh/255.f; const int probability[] = {
float blight = region->mData.mBlight/255.f; region->mData.mClear,
float snow = region->mData.mA/255.f; region->mData.mCloudy,
float blizzard = region->mData.mB/255.f; region->mData.mFoggy,
region->mData.mOvercast,
region->mData.mRain,
region->mData.mThunder,
region->mData.mAsh,
region->mData.mBlight,
region->mData.mA,
region->mData.mB
}; // 10 elements
// re-scale to 100 percent int chance = (rand() % 100) + 1; // 1..100
const float total = clear+cloudy+foggy+overcast+rain+thunder+ash+blight+snow+blizzard; int sum = 0;
for (int i = 0; i < 10; ++i)
float random = ((rand()%100)/100.f) * total; {
sum += probability[i];
if (random >= snow+blight+ash+thunder+rain+overcast+foggy+cloudy+clear) if (chance < sum)
weatherType = Weather::Type_Blizzard; {
else if (random >= blight+ash+thunder+rain+overcast+foggy+cloudy+clear) weatherType = (Weather::Type)i;
weatherType = Weather::Type_Snow; break;
else if (random >= ash+thunder+rain+overcast+foggy+cloudy+clear) }
weatherType = Weather::Type_Blight; }
else if (random >= thunder+rain+overcast+foggy+cloudy+clear)
weatherType = Weather::Type_Ashstorm;
else if (random >= rain+overcast+foggy+cloudy+clear)
weatherType = Weather::Type_Thunderstorm;
else if (random >= overcast+foggy+cloudy+clear)
weatherType = Weather::Type_Rain;
else if (random >= foggy+cloudy+clear)
weatherType = Weather::Type_Overcast;
else if (random >= cloudy+clear)
weatherType = Weather::Type_Foggy;
else if (random >= clear)
weatherType = Weather::Type_Cloudy;
else
weatherType = Weather::Type_Clear;
} }
} }
@ -461,8 +455,8 @@ void WeatherManager::update(float duration)
int facing = (mHour > 13.f) ? 1 : -1; int facing = (mHour > 13.f) ? 1 : -1;
Vector3 final( Vector3 final(
-(1 - height) * facing, (height - 1) * facing,
-(1 - height) * facing, (height - 1) * facing,
height); height);
mRendering->setSunDirection(final); mRendering->setSunDirection(final);