mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-20 07:53:51 +00:00
c64eb96952
Conflicts: apps/openmw/CMakeLists.txt apps/openmw/mwgui/dialogue.cpp apps/openmw/mwrender/globalmap.cpp files/mygui/CMakeLists.txt
133 lines
3.4 KiB
C++
133 lines
3.4 KiB
C++
#include "fader.hpp"
|
|
|
|
#include <OgreMaterial.h>
|
|
#include <OgreTechnique.h>
|
|
#include <OgreMaterialManager.h>
|
|
#include <OgreResourceGroupManager.h>
|
|
#include <OgreRectangle2D.h>
|
|
#include <OgreSceneManager.h>
|
|
|
|
|
|
using namespace Ogre;
|
|
using namespace OEngine::Render;
|
|
|
|
Fader::Fader(Ogre::SceneManager* sceneMgr)
|
|
: mSceneMgr(sceneMgr)
|
|
, mMode(FadingMode_In)
|
|
, mRemainingTime(0.f)
|
|
, mTargetTime(0.f)
|
|
, mTargetAlpha(0.f)
|
|
, mCurrentAlpha(0.f)
|
|
, mStartAlpha(0.f)
|
|
{
|
|
// Create the fading material
|
|
MaterialPtr material = MaterialManager::getSingleton().create("FadeInOutMaterial", ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME );
|
|
Pass* pass = material->getTechnique(0)->getPass(0);
|
|
pass->setSceneBlending(SBT_TRANSPARENT_ALPHA);
|
|
pass->setDepthWriteEnabled (false);
|
|
mFadeTextureUnit = pass->createTextureUnitState("black.png");
|
|
mFadeTextureUnit->setColourOperationEx(LBX_SOURCE1, LBS_MANUAL, LBS_CURRENT, ColourValue(0.f, 0.f, 0.f)); // always black colour
|
|
|
|
mRectangle = new Ogre::Rectangle2D(true);
|
|
mRectangle->setCorners(-1.0, 1.0, 1.0, -1.0);
|
|
mRectangle->setMaterial("FadeInOutMaterial");
|
|
mRectangle->setRenderQueueGroup(Ogre::RENDER_QUEUE_OVERLAY-1);
|
|
// Use infinite AAB to always stay visible
|
|
Ogre::AxisAlignedBox aabInf;
|
|
aabInf.setInfinite();
|
|
mRectangle->setBoundingBox(aabInf);
|
|
// Attach background to the scene
|
|
Ogre::SceneNode* node = mSceneMgr->getRootSceneNode()->createChildSceneNode();
|
|
node->attachObject(mRectangle);
|
|
mRectangle->setVisible(false);
|
|
mRectangle->setVisibilityFlags (2048);
|
|
}
|
|
|
|
Fader::~Fader()
|
|
{
|
|
delete mRectangle;
|
|
}
|
|
|
|
void Fader::update(float dt)
|
|
{
|
|
if (mRemainingTime > 0)
|
|
{
|
|
if (mMode == FadingMode_In)
|
|
{
|
|
mCurrentAlpha -= dt/mTargetTime * (mStartAlpha-mTargetAlpha);
|
|
if (mCurrentAlpha < mTargetAlpha) mCurrentAlpha = mTargetAlpha;
|
|
}
|
|
else if (mMode == FadingMode_Out)
|
|
{
|
|
mCurrentAlpha += dt/mTargetTime * (mTargetAlpha-mStartAlpha);
|
|
if (mCurrentAlpha > mTargetAlpha) mCurrentAlpha = mTargetAlpha;
|
|
}
|
|
|
|
applyAlpha();
|
|
|
|
mRemainingTime -= dt;
|
|
}
|
|
|
|
if (mCurrentAlpha == 0.f) mRectangle->setVisible(false);
|
|
}
|
|
|
|
void Fader::applyAlpha()
|
|
{
|
|
mRectangle->setVisible(true);
|
|
mFadeTextureUnit->setAlphaOperation(LBX_SOURCE1, LBS_MANUAL, LBS_CURRENT, mCurrentAlpha);
|
|
}
|
|
|
|
void Fader::fadeIn(float time)
|
|
{
|
|
if (time<0.f) return;
|
|
if (time==0.f)
|
|
{
|
|
mCurrentAlpha = 0.f;
|
|
applyAlpha();
|
|
return;
|
|
}
|
|
|
|
mStartAlpha = mCurrentAlpha;
|
|
mTargetAlpha = 0.f;
|
|
mMode = FadingMode_In;
|
|
mTargetTime = time;
|
|
mRemainingTime = time;
|
|
}
|
|
|
|
void Fader::fadeOut(const float time)
|
|
{
|
|
if (time<0.f) return;
|
|
if (time==0.f)
|
|
{
|
|
mCurrentAlpha = 1.f;
|
|
applyAlpha();
|
|
return;
|
|
}
|
|
|
|
mStartAlpha = mCurrentAlpha;
|
|
mTargetAlpha = 1.f;
|
|
mMode = FadingMode_Out;
|
|
mTargetTime = time;
|
|
mRemainingTime = time;
|
|
}
|
|
|
|
void Fader::fadeTo(const int percent, const float time)
|
|
{
|
|
if (time<0.f) return;
|
|
if (time==0.f)
|
|
{
|
|
mCurrentAlpha = percent/100.f;
|
|
applyAlpha();
|
|
return;
|
|
}
|
|
|
|
mStartAlpha = mCurrentAlpha;
|
|
mTargetAlpha = percent/100.f;
|
|
|
|
if (mTargetAlpha == mStartAlpha) return;
|
|
else if (mTargetAlpha > mStartAlpha) mMode = FadingMode_Out;
|
|
else mMode = FadingMode_In;
|
|
|
|
mTargetTime = time;
|
|
mRemainingTime = time;
|
|
}
|