Rain fading

c++11
scrawl 10 years ago
parent 3a21f05f6e
commit 8a3889a81e

@ -687,6 +687,37 @@ private:
float mAngle; float mAngle;
}; };
class RainFader : public SceneUtil::StateSetUpdater
{
public:
RainFader()
: mAlpha(1.f)
{
}
void setAlpha(float alpha)
{
mAlpha = alpha;
}
virtual void setDefaults(osg::StateSet* stateset)
{
osg::ref_ptr<osg::Material> mat (new osg::Material);
mat->setEmission(osg::Material::FRONT_AND_BACK, osg::Vec4f(1,1,1,1));
mat->setAmbient(osg::Material::FRONT_AND_BACK, osg::Vec4f(0,0,0,1));
stateset->setAttributeAndModes(mat, osg::StateAttribute::ON);
}
virtual void apply(osg::StateSet* stateset, osg::NodeVisitor* nv)
{
osg::Material* mat = static_cast<osg::Material*>(stateset->getAttribute(osg::StateAttribute::MATERIAL));
mat->setDiffuse(osg::Material::FRONT_AND_BACK, osg::Vec4f(0,0,0,mAlpha));
}
private:
float mAlpha;
};
void SkyManager::createRain() void SkyManager::createRain()
{ {
if (mRainNode) if (mRainNode)
@ -704,7 +735,6 @@ void SkyManager::createRain()
osg::Texture::CLAMP, osg::Texture::CLAMP), osg::StateAttribute::ON); osg::Texture::CLAMP, osg::Texture::CLAMP), osg::StateAttribute::ON);
stateset->setNestRenderBins(false); stateset->setNestRenderBins(false);
stateset->setRenderingHint(osg::StateSet::TRANSPARENT_BIN); stateset->setRenderingHint(osg::StateSet::TRANSPARENT_BIN);
stateset->setMode(GL_LIGHTING, osg::StateAttribute::OFF);
stateset->setMode(GL_CULL_FACE, osg::StateAttribute::OFF); stateset->setMode(GL_CULL_FACE, osg::StateAttribute::OFF);
osgParticle::Particle& particleTemplate = mRainParticleSystem->getDefaultParticleTemplate(); osgParticle::Particle& particleTemplate = mRainParticleSystem->getDefaultParticleTemplate();
@ -739,6 +769,9 @@ void SkyManager::createRain()
mRainNode->addChild(geode); mRainNode->addChild(geode);
mRainNode->addChild(updater); mRainNode->addChild(updater);
mRainFader = new RainFader;
mRainNode->addUpdateCallback(mRainFader);
mRootNode->addChild(mRainNode); mRootNode->addChild(mRainNode);
} }
@ -751,6 +784,7 @@ void SkyManager::destroyRain()
mRainNode = NULL; mRainNode = NULL;
mRainParticleSystem = NULL; mRainParticleSystem = NULL;
mRainShooter = NULL; mRainShooter = NULL;
mRainFader = NULL;
} }
SkyManager::~SkyManager() SkyManager::~SkyManager()
@ -851,8 +885,9 @@ void SkyManager::updateRainParameters()
{ {
if (mRainShooter) if (mRainShooter)
{ {
float angle = mWindSpeed/2.f * osg::PI/4; float windFactor = mWindSpeed/3.f;
mRainShooter->setVelocity(osg::Vec3f(0, mRainSpeed * mWindSpeed / 2.f, -mRainSpeed)); float angle = windFactor * osg::PI/4;
mRainShooter->setVelocity(osg::Vec3f(0, mRainSpeed * windFactor, -mRainSpeed));
mRainShooter->setAngle(angle); mRainShooter->setAngle(angle);
} }
} }
@ -991,9 +1026,10 @@ void SkyManager::setWeather(const MWWorld::WeatherResult& weather)
if (mParticle.get()) if (mParticle.get())
setAlpha(mParticle, weather.mEffectFade); setAlpha(mParticle, weather.mEffectFade);
for (std::map<Ogre::SceneNode*, NifOgre::ObjectScenePtr>::iterator it = mRainModels.begin(); it != mRainModels.end(); ++it)
setAlpha(it->second, weather.mEffectFade);
*/ */
if (mRainFader)
mRainFader->setAlpha(weather.mEffectFade * 0.6); // * Rain_Threshold?
} }
void SkyManager::setGlare(const float glare) void SkyManager::setGlare(const float glare)

@ -30,6 +30,7 @@ namespace MWRender
class Sun; class Sun;
class Moon; class Moon;
class RainShooter; class RainShooter;
class RainFader;
class SkyManager class SkyManager
{ {
@ -126,6 +127,7 @@ namespace MWRender
osg::ref_ptr<osg::Group> mRainNode; osg::ref_ptr<osg::Group> mRainNode;
osg::ref_ptr<osgParticle::ParticleSystem> mRainParticleSystem; osg::ref_ptr<osgParticle::ParticleSystem> mRainParticleSystem;
osg::ref_ptr<RainShooter> mRainShooter; osg::ref_ptr<RainShooter> mRainShooter;
osg::ref_ptr<RainFader> mRainFader;
bool mCreated; bool mCreated;

Loading…
Cancel
Save