|
|
@ -219,6 +219,7 @@ SkyManager::SkyManager(Ogre::SceneNode *root, Ogre::Camera *pCamera)
|
|
|
|
, mSceneMgr(NULL)
|
|
|
|
, mSceneMgr(NULL)
|
|
|
|
, mAtmosphereDay(NULL)
|
|
|
|
, mAtmosphereDay(NULL)
|
|
|
|
, mAtmosphereNight(NULL)
|
|
|
|
, mAtmosphereNight(NULL)
|
|
|
|
|
|
|
|
, mCloudNode(NULL)
|
|
|
|
, mClouds()
|
|
|
|
, mClouds()
|
|
|
|
, mNextClouds()
|
|
|
|
, mNextClouds()
|
|
|
|
, mCloudBlendFactor(0.0f)
|
|
|
|
, mCloudBlendFactor(0.0f)
|
|
|
@ -240,10 +241,11 @@ SkyManager::SkyManager(Ogre::SceneNode *root, Ogre::Camera *pCamera)
|
|
|
|
, mRainTimer(0)
|
|
|
|
, mRainTimer(0)
|
|
|
|
, mRainSpeed(0)
|
|
|
|
, mRainSpeed(0)
|
|
|
|
, mRainFrequency(1)
|
|
|
|
, mRainFrequency(1)
|
|
|
|
|
|
|
|
, mStormDirection(0,-1,0)
|
|
|
|
|
|
|
|
, mIsStorm(false)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mSceneMgr = root->getCreator();
|
|
|
|
mSceneMgr = root->getCreator();
|
|
|
|
mRootNode = mSceneMgr->getRootSceneNode()->createChildSceneNode();
|
|
|
|
mRootNode = mSceneMgr->getRootSceneNode()->createChildSceneNode();
|
|
|
|
mRootNode->setInheritOrientation(false);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SkyManager::create()
|
|
|
|
void SkyManager::create()
|
|
|
@ -335,8 +337,8 @@ void SkyManager::create()
|
|
|
|
mObjects.push_back(objects);
|
|
|
|
mObjects.push_back(objects);
|
|
|
|
|
|
|
|
|
|
|
|
// Clouds
|
|
|
|
// Clouds
|
|
|
|
SceneNode* clouds_node = mRootNode->createChildSceneNode();
|
|
|
|
mCloudNode = mRootNode->createChildSceneNode();
|
|
|
|
objects = NifOgre::Loader::createObjects(clouds_node, "meshes\\sky_clouds_01.nif");
|
|
|
|
objects = NifOgre::Loader::createObjects(mCloudNode, "meshes\\sky_clouds_01.nif");
|
|
|
|
for(size_t i = 0;i < objects->mEntities.size();i++)
|
|
|
|
for(size_t i = 0;i < objects->mEntities.size();i++)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Entity* clouds_ent = objects->mEntities[i];
|
|
|
|
Entity* clouds_ent = objects->mEntities[i];
|
|
|
@ -453,8 +455,16 @@ void SkyManager::update(float duration)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
for (unsigned int i=0; i<mParticle->mControllers.size(); ++i)
|
|
|
|
for (unsigned int i=0; i<mParticle->mControllers.size(); ++i)
|
|
|
|
mParticle->mControllers[i].update();
|
|
|
|
mParticle->mControllers[i].update();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (mIsStorm)
|
|
|
|
|
|
|
|
mParticleNode->setOrientation(Ogre::Vector3::UNIT_Y.getRotationTo(mStormDirection));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (mIsStorm)
|
|
|
|
|
|
|
|
mCloudNode->setOrientation(Ogre::Vector3::UNIT_Y.getRotationTo(mStormDirection));
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
mCloudNode->setOrientation(Ogre::Quaternion::IDENTITY);
|
|
|
|
|
|
|
|
|
|
|
|
updateRain(duration);
|
|
|
|
updateRain(duration);
|
|
|
|
|
|
|
|
|
|
|
|
// UV Scroll the clouds
|
|
|
|
// UV Scroll the clouds
|
|
|
@ -539,6 +549,7 @@ void SkyManager::setWeather(const MWWorld::WeatherResult& weather)
|
|
|
|
mRainEnabled = !mRainEffect.empty();
|
|
|
|
mRainEnabled = !mRainEffect.empty();
|
|
|
|
mRainFrequency = weather.mRainFrequency;
|
|
|
|
mRainFrequency = weather.mRainFrequency;
|
|
|
|
mRainSpeed = weather.mRainSpeed;
|
|
|
|
mRainSpeed = weather.mRainSpeed;
|
|
|
|
|
|
|
|
mIsStorm = weather.mIsStorm;
|
|
|
|
|
|
|
|
|
|
|
|
if (mCurrentParticleEffect != weather.mParticleEffect)
|
|
|
|
if (mCurrentParticleEffect != weather.mParticleEffect)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -676,6 +687,11 @@ void SkyManager::sunDisable()
|
|
|
|
mSunEnabled = false;
|
|
|
|
mSunEnabled = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SkyManager::setStormDirection(const Vector3 &direction)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mStormDirection = direction;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SkyManager::setSunDirection(const Vector3& direction, bool is_moon)
|
|
|
|
void SkyManager::setSunDirection(const Vector3& direction, bool is_moon)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (!mCreated) return;
|
|
|
|
if (!mCreated) return;
|
|
|
|