2011-10-20 15:02:19 -04:00
|
|
|
#include "renderingmanager.hpp"
|
|
|
|
|
2011-10-20 18:15:30 -04:00
|
|
|
#include <assert.h>
|
|
|
|
|
|
|
|
#include "OgreRoot.h"
|
|
|
|
#include "OgreRenderWindow.h"
|
|
|
|
#include "OgreSceneManager.h"
|
|
|
|
#include "OgreViewport.h"
|
|
|
|
#include "OgreCamera.h"
|
|
|
|
#include "OgreTextureManager.h"
|
|
|
|
|
|
|
|
#include "../mwworld/world.hpp" // these includes can be removed once the static-hack is gone
|
|
|
|
#include "../mwworld/ptr.hpp"
|
|
|
|
#include <components/esm/loadstat.hpp>
|
2012-04-02 15:51:48 +02:00
|
|
|
#include <components/settings/settings.hpp>
|
2011-10-20 18:15:30 -04:00
|
|
|
|
2012-04-11 18:53:13 +02:00
|
|
|
#include "shadows.hpp"
|
|
|
|
#include "shaderhelper.hpp"
|
|
|
|
#include "localmap.hpp"
|
|
|
|
#include "water.hpp"
|
2011-10-31 23:59:16 -04:00
|
|
|
|
2011-10-20 18:15:30 -04:00
|
|
|
using namespace MWRender;
|
|
|
|
using namespace Ogre;
|
|
|
|
|
2011-10-20 15:02:19 -04:00
|
|
|
namespace MWRender {
|
|
|
|
|
2011-12-09 00:08:30 -05:00
|
|
|
RenderingManager::RenderingManager (OEngine::Render::OgreRenderer& _rend, const boost::filesystem::path& resDir, OEngine::Physic::PhysicEngine* engine, MWWorld::Environment& environment)
|
2012-04-11 18:53:13 +02:00
|
|
|
:mRendering(_rend), mObjects(mRendering), mActors(mRendering, environment), mAmbientMode(0), mSunEnabled(0)
|
2011-10-20 15:02:19 -04:00
|
|
|
{
|
2012-04-02 18:01:49 +02:00
|
|
|
mRendering.createScene("PlayerCam", Settings::Manager::getFloat("field of view", "General"), 5);
|
2011-10-20 18:15:30 -04:00
|
|
|
|
2012-04-05 15:30:55 +02:00
|
|
|
mWater = 0;
|
|
|
|
|
2012-03-02 22:31:17 +00:00
|
|
|
//The fog type must be set before any terrain objects are created as if the
|
|
|
|
//fog type is set to FOG_NONE then the initially created terrain won't have any fog
|
|
|
|
configureFog(1, ColourValue(1,1,1));
|
2011-10-20 18:15:30 -04:00
|
|
|
|
|
|
|
// Set default mipmap level (NB some APIs ignore this)
|
2012-04-02 18:01:49 +02:00
|
|
|
TextureManager::getSingleton().setDefaultNumMipmaps(Settings::Manager::getInt("num mipmaps", "General"));
|
|
|
|
|
|
|
|
// Set default texture filtering options
|
|
|
|
TextureFilterOptions tfo;
|
|
|
|
std::string filter = Settings::Manager::getString("texture filtering", "General");
|
|
|
|
if (filter == "anisotropic") tfo = TFO_ANISOTROPIC;
|
|
|
|
else if (filter == "trilinear") tfo = TFO_TRILINEAR;
|
2012-04-09 00:10:42 +02:00
|
|
|
else if (filter == "bilinear") tfo = TFO_BILINEAR;
|
|
|
|
else if (filter == "none") tfo = TFO_NONE;
|
2012-04-02 18:01:49 +02:00
|
|
|
|
|
|
|
MaterialManager::getSingleton().setDefaultTextureFiltering(tfo);
|
2012-04-09 00:10:42 +02:00
|
|
|
MaterialManager::getSingleton().setDefaultAnisotropy( (filter == "anisotropic") ? Settings::Manager::getInt("anisotropy", "General") : 1 );
|
2011-10-20 18:15:30 -04:00
|
|
|
|
|
|
|
// Load resources
|
|
|
|
ResourceGroupManager::getSingleton().initialiseAllResourceGroups();
|
|
|
|
|
2012-04-05 19:27:54 +02:00
|
|
|
// disable unsupported effects
|
2012-04-05 13:09:59 +02:00
|
|
|
const RenderSystemCapabilities* caps = Root::getSingleton().getRenderSystem()->getCapabilities();
|
2012-04-05 15:30:55 +02:00
|
|
|
if (caps->getNumMultiRenderTargets() < 2)
|
2012-04-05 19:27:54 +02:00
|
|
|
Settings::Manager::setBool("shader", "Water", false);
|
2012-04-13 13:28:31 +02:00
|
|
|
if (!caps->isShaderProfileSupported("fp40") && !caps->isShaderProfileSupported("ps_4_0"))
|
|
|
|
Settings::Manager::setBool("enabled", "Shadows", false);
|
2012-04-05 13:09:59 +02:00
|
|
|
|
2012-04-06 16:11:08 +02:00
|
|
|
// note that the order is important here
|
2012-04-05 19:27:54 +02:00
|
|
|
if (useMRT())
|
2012-04-05 01:21:36 +02:00
|
|
|
{
|
|
|
|
CompositorManager::getSingleton().addCompositor(mRendering.getViewport(), "gbuffer");
|
|
|
|
CompositorManager::getSingleton().setCompositorEnabled(mRendering.getViewport(), "gbuffer", true);
|
2012-04-06 18:51:30 +02:00
|
|
|
CompositorManager::getSingleton().addCompositor(mRendering.getViewport(), "Underwater");
|
2012-04-05 01:21:36 +02:00
|
|
|
CompositorManager::getSingleton().addCompositor(mRendering.getViewport(), "gbufferFinalizer");
|
|
|
|
CompositorManager::getSingleton().setCompositorEnabled(mRendering.getViewport(), "gbufferFinalizer", true);
|
2012-04-06 18:22:37 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
CompositorManager::getSingleton().addCompositor(mRendering.getViewport(), "UnderwaterNoMRT");
|
2012-04-05 01:21:36 +02:00
|
|
|
}
|
|
|
|
|
2011-10-20 18:15:30 -04:00
|
|
|
// Turn the entire scene (represented by the 'root' node) -90
|
|
|
|
// degrees around the x axis. This makes Z go upwards, and Y go into
|
|
|
|
// the screen (when x is to the right.) This is the orientation that
|
|
|
|
// Morrowind uses, and it automagically makes everything work as it
|
|
|
|
// should.
|
2011-11-22 02:39:28 -05:00
|
|
|
SceneNode *rt = mRendering.getScene()->getRootSceneNode();
|
|
|
|
mMwRoot = rt->createChildSceneNode();
|
|
|
|
mMwRoot->pitch(Degree(-90));
|
|
|
|
mObjects.setMwRoot(mMwRoot);
|
2011-11-24 23:13:34 -05:00
|
|
|
mActors.setMwRoot(mMwRoot);
|
2011-10-20 18:15:30 -04:00
|
|
|
|
2011-11-22 02:39:28 -05:00
|
|
|
Ogre::SceneNode *playerNode = mMwRoot->createChildSceneNode ("player");
|
2011-10-20 18:15:30 -04:00
|
|
|
playerNode->pitch(Degree(90));
|
|
|
|
Ogre::SceneNode *cameraYawNode = playerNode->createChildSceneNode();
|
|
|
|
Ogre::SceneNode *cameraPitchNode = cameraYawNode->createChildSceneNode();
|
2011-11-22 02:39:28 -05:00
|
|
|
cameraPitchNode->attachObject(mRendering.getCamera());
|
2012-03-08 10:46:34 +04:00
|
|
|
|
2012-04-11 18:53:13 +02:00
|
|
|
mShadows = new Shadows(&mRendering);
|
|
|
|
mShaderHelper = new ShaderHelper(this);
|
|
|
|
|
|
|
|
mTerrainManager = new TerrainManager(mRendering.getScene(), this,
|
|
|
|
environment);
|
|
|
|
|
2012-02-21 16:49:28 +01:00
|
|
|
//mSkyManager = 0;
|
2012-03-16 19:02:33 +01:00
|
|
|
mSkyManager = new SkyManager(mMwRoot, mRendering.getCamera(), &environment);
|
2011-10-20 18:15:30 -04:00
|
|
|
|
2012-03-24 17:59:26 +01:00
|
|
|
mOcclusionQuery = new OcclusionQuery(&mRendering, mSkyManager->getSunNode());
|
2012-01-22 15:02:38 -05:00
|
|
|
|
2011-11-22 02:39:28 -05:00
|
|
|
mPlayer = new MWRender::Player (mRendering.getCamera(), playerNode);
|
2012-02-08 00:32:22 +01:00
|
|
|
mSun = 0;
|
2012-03-10 15:28:18 +01:00
|
|
|
|
2012-03-12 02:12:56 +04:00
|
|
|
mDebugging = new Debugging(mMwRoot, environment, engine);
|
2012-04-02 19:37:24 +02:00
|
|
|
mLocalMap = new MWRender::LocalMap(&mRendering, this, &environment);
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
RenderingManager::~RenderingManager ()
|
|
|
|
{
|
2011-11-21 12:52:28 +01:00
|
|
|
delete mPlayer;
|
2011-10-20 15:02:19 -04:00
|
|
|
delete mSkyManager;
|
2012-03-08 10:46:34 +04:00
|
|
|
delete mDebugging;
|
2012-01-21 16:59:08 +00:00
|
|
|
delete mTerrainManager;
|
2012-03-10 15:28:18 +01:00
|
|
|
delete mLocalMap;
|
2012-03-24 13:06:01 +01:00
|
|
|
delete mOcclusionQuery;
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
|
|
|
|
2012-02-22 19:17:37 +01:00
|
|
|
MWRender::SkyManager* RenderingManager::getSkyManager()
|
|
|
|
{
|
|
|
|
return mSkyManager;
|
2011-10-31 23:59:16 -04:00
|
|
|
}
|
2011-11-24 01:48:54 -05:00
|
|
|
|
2011-10-31 23:59:16 -04:00
|
|
|
MWRender::Objects& RenderingManager::getObjects(){
|
2011-11-22 02:39:28 -05:00
|
|
|
return mObjects;
|
2011-10-31 23:59:16 -04:00
|
|
|
}
|
2011-11-24 01:48:54 -05:00
|
|
|
MWRender::Actors& RenderingManager::getActors(){
|
|
|
|
return mActors;
|
2011-10-31 23:59:16 -04:00
|
|
|
}
|
2011-11-24 01:48:54 -05:00
|
|
|
|
2011-11-01 13:46:57 -04:00
|
|
|
MWRender::Player& RenderingManager::getPlayer(){
|
|
|
|
return (*mPlayer);
|
2011-10-31 23:59:16 -04:00
|
|
|
}
|
|
|
|
|
2012-02-18 18:25:28 +01:00
|
|
|
OEngine::Render::Fader* RenderingManager::getFader()
|
|
|
|
{
|
|
|
|
return mRendering.getFader();
|
|
|
|
}
|
|
|
|
|
2012-03-29 18:33:08 +02:00
|
|
|
void RenderingManager::removeCell (MWWorld::Ptr::CellStore *store)
|
|
|
|
{
|
|
|
|
mObjects.removeCell(store);
|
2011-11-24 23:13:34 -05:00
|
|
|
mActors.removeCell(store);
|
2012-03-08 10:46:34 +04:00
|
|
|
mDebugging->cellRemoved(store);
|
2012-01-22 20:20:12 +04:00
|
|
|
if (store->cell->isExterior())
|
|
|
|
mTerrainManager->cellRemoved(store);
|
2012-01-21 20:05:08 -05:00
|
|
|
}
|
2012-03-29 18:33:08 +02:00
|
|
|
|
|
|
|
void RenderingManager::removeWater ()
|
|
|
|
{
|
2012-01-19 23:29:07 -05:00
|
|
|
if(mWater){
|
2012-04-03 15:13:47 +02:00
|
|
|
mWater->setActive(false);
|
2012-01-19 23:29:07 -05:00
|
|
|
}
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
2011-11-21 12:52:28 +01:00
|
|
|
|
2012-03-29 18:33:08 +02:00
|
|
|
void RenderingManager::toggleWater()
|
|
|
|
{
|
|
|
|
if (mWater)
|
|
|
|
mWater->toggle();
|
|
|
|
}
|
|
|
|
|
2011-11-21 12:52:28 +01:00
|
|
|
void RenderingManager::cellAdded (MWWorld::Ptr::CellStore *store)
|
|
|
|
{
|
2011-11-22 02:39:28 -05:00
|
|
|
mObjects.buildStaticGeometry (*store);
|
2012-03-08 10:46:34 +04:00
|
|
|
mDebugging->cellAdded(store);
|
2012-01-22 20:20:12 +04:00
|
|
|
if (store->cell->isExterior())
|
|
|
|
mTerrainManager->cellAdded(store);
|
2012-04-03 16:53:33 +02:00
|
|
|
waterAdded(store);
|
2011-11-21 12:52:28 +01:00
|
|
|
}
|
|
|
|
|
2011-11-11 00:20:53 -05:00
|
|
|
void RenderingManager::addObject (const MWWorld::Ptr& ptr){
|
2011-11-16 16:22:13 -05:00
|
|
|
const MWWorld::Class& class_ =
|
|
|
|
MWWorld::Class::get (ptr);
|
|
|
|
class_.insertObjectRendering(ptr, *this);
|
2011-10-20 15:02:19 -04:00
|
|
|
|
|
|
|
}
|
2011-11-21 12:52:28 +01:00
|
|
|
void RenderingManager::removeObject (const MWWorld::Ptr& ptr)
|
|
|
|
{
|
2011-11-22 02:39:28 -05:00
|
|
|
if (!mObjects.deleteObject (ptr))
|
2011-11-21 12:52:28 +01:00
|
|
|
{
|
|
|
|
/// \todo delete non-object MW-references
|
|
|
|
}
|
2011-11-24 23:13:34 -05:00
|
|
|
if (!mActors.deleteObject (ptr))
|
2011-11-21 12:52:28 +01:00
|
|
|
{
|
|
|
|
/// \todo delete non-object MW-references
|
|
|
|
}
|
|
|
|
}
|
2011-10-20 15:02:19 -04:00
|
|
|
|
2011-11-21 12:52:28 +01:00
|
|
|
void RenderingManager::moveObject (const MWWorld::Ptr& ptr, const Ogre::Vector3& position)
|
|
|
|
{
|
|
|
|
/// \todo move this to the rendering-subsystems
|
2011-11-22 02:39:28 -05:00
|
|
|
mRendering.getScene()->getSceneNode (ptr.getRefData().getHandle())->
|
2011-11-21 12:52:28 +01:00
|
|
|
setPosition (position);
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
2011-11-21 12:52:28 +01:00
|
|
|
|
2011-10-20 15:02:19 -04:00
|
|
|
void RenderingManager::scaleObject (const MWWorld::Ptr& ptr, const Ogre::Vector3& scale){
|
|
|
|
|
|
|
|
}
|
|
|
|
void RenderingManager::rotateObject (const MWWorld::Ptr& ptr, const::Ogre::Quaternion& orientation){
|
|
|
|
|
|
|
|
}
|
|
|
|
void RenderingManager::moveObjectToCell (const MWWorld::Ptr& ptr, const Ogre::Vector3& position, MWWorld::Ptr::CellStore *store){
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void RenderingManager::update (float duration){
|
|
|
|
|
2012-01-23 14:33:06 +01:00
|
|
|
mActors.update (duration);
|
2012-03-24 17:59:26 +01:00
|
|
|
|
2012-03-26 00:31:03 +02:00
|
|
|
mOcclusionQuery->update(duration);
|
2012-03-24 17:59:26 +01:00
|
|
|
|
2012-02-19 23:09:14 +01:00
|
|
|
mSkyManager->update(duration);
|
2012-03-24 17:59:26 +01:00
|
|
|
|
|
|
|
mSkyManager->setGlare(mOcclusionQuery->getSunVisibility());
|
|
|
|
|
2012-02-19 23:22:29 +01:00
|
|
|
mRendering.update(duration);
|
2012-03-14 14:51:58 +01:00
|
|
|
|
2012-03-30 16:34:36 +02:00
|
|
|
mLocalMap->updatePlayer( mRendering.getCamera()->getRealPosition(), mRendering.getCamera()->getRealOrientation() );
|
2012-03-29 05:03:34 +02:00
|
|
|
|
|
|
|
checkUnderwater();
|
2012-01-19 23:29:07 -05:00
|
|
|
}
|
2012-01-22 15:02:38 -05:00
|
|
|
void RenderingManager::waterAdded (MWWorld::Ptr::CellStore *store){
|
2012-01-21 20:05:08 -05:00
|
|
|
if(store->cell->data.flags & store->cell->HasWater){
|
|
|
|
if(mWater == 0)
|
2012-04-03 21:16:43 +02:00
|
|
|
mWater = new MWRender::Water(mRendering.getCamera(), mSkyManager, store->cell);
|
2012-01-22 16:38:10 -05:00
|
|
|
else
|
|
|
|
mWater->changeCell(store->cell);
|
2012-04-03 15:13:47 +02:00
|
|
|
mWater->setActive(true);
|
2012-01-21 20:05:08 -05:00
|
|
|
}
|
2012-01-22 16:38:10 -05:00
|
|
|
else
|
|
|
|
removeWater();
|
2012-04-02 12:04:47 +02:00
|
|
|
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
|
|
|
|
2012-03-29 15:49:24 +02:00
|
|
|
void RenderingManager::setWaterHeight(const float height)
|
|
|
|
{
|
|
|
|
if (mWater)
|
|
|
|
mWater->setHeight(height);
|
|
|
|
}
|
|
|
|
|
2011-10-20 15:02:19 -04:00
|
|
|
void RenderingManager::skyEnable ()
|
|
|
|
{
|
2012-01-25 01:21:30 -05:00
|
|
|
if(mSkyManager)
|
2011-10-20 15:02:19 -04:00
|
|
|
mSkyManager->enable();
|
2012-04-01 15:07:41 +02:00
|
|
|
|
|
|
|
mOcclusionQuery->setSunNode(mSkyManager->getSunNode());
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void RenderingManager::skyDisable ()
|
|
|
|
{
|
2012-01-25 01:21:30 -05:00
|
|
|
if(mSkyManager)
|
|
|
|
mSkyManager->disable();
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void RenderingManager::skySetHour (double hour)
|
|
|
|
{
|
2012-01-25 01:21:30 -05:00
|
|
|
if(mSkyManager)
|
|
|
|
mSkyManager->setHour(hour);
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void RenderingManager::skySetDate (int day, int month)
|
|
|
|
{
|
2012-01-25 01:21:30 -05:00
|
|
|
if(mSkyManager)
|
|
|
|
mSkyManager->setDate(day, month);
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
int RenderingManager::skyGetMasserPhase() const
|
|
|
|
{
|
2012-03-08 10:46:34 +04:00
|
|
|
|
2011-10-20 15:02:19 -04:00
|
|
|
return mSkyManager->getMasserPhase();
|
|
|
|
}
|
|
|
|
|
|
|
|
int RenderingManager::skyGetSecundaPhase() const
|
|
|
|
{
|
|
|
|
return mSkyManager->getSecundaPhase();
|
|
|
|
}
|
|
|
|
|
2012-01-25 01:21:30 -05:00
|
|
|
void RenderingManager::skySetMoonColour (bool red){
|
|
|
|
if(mSkyManager)
|
|
|
|
mSkyManager->setMoonColour(red);
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
2012-02-18 16:06:03 +01:00
|
|
|
|
|
|
|
bool RenderingManager::toggleRenderMode(int mode)
|
|
|
|
{
|
2012-03-08 10:46:34 +04:00
|
|
|
if (mode != MWWorld::World::Render_Wireframe)
|
|
|
|
return mDebugging->toggleRenderMode(mode);
|
2012-02-18 16:06:03 +01:00
|
|
|
else // if (mode == MWWorld::World::Render_Wireframe)
|
|
|
|
{
|
|
|
|
if (mRendering.getCamera()->getPolygonMode() == PM_SOLID)
|
|
|
|
{
|
2012-04-05 01:21:36 +02:00
|
|
|
// disable compositors
|
2012-04-05 19:27:54 +02:00
|
|
|
if (useMRT())
|
|
|
|
{
|
|
|
|
CompositorManager::getSingleton().setCompositorEnabled(mRendering.getViewport(), "gbuffer", false);
|
|
|
|
CompositorManager::getSingleton().setCompositorEnabled(mRendering.getViewport(), "gbufferFinalizer", false);
|
|
|
|
}
|
2012-04-05 01:21:36 +02:00
|
|
|
|
2012-02-18 16:06:03 +01:00
|
|
|
mRendering.getCamera()->setPolygonMode(PM_WIREFRAME);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2012-04-05 01:21:36 +02:00
|
|
|
// re-enable compositors
|
2012-04-05 19:27:54 +02:00
|
|
|
if (useMRT())
|
2012-04-05 01:21:36 +02:00
|
|
|
{
|
|
|
|
CompositorManager::getSingleton().setCompositorEnabled(mRendering.getViewport(), "gbuffer", true);
|
|
|
|
CompositorManager::getSingleton().setCompositorEnabled(mRendering.getViewport(), "gbufferFinalizer", true);
|
|
|
|
}
|
|
|
|
|
2012-02-18 16:06:03 +01:00
|
|
|
mRendering.getCamera()->setPolygonMode(PM_SOLID);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2011-10-30 00:25:29 -04:00
|
|
|
}
|
2011-10-20 15:02:19 -04:00
|
|
|
|
2011-11-03 23:47:15 -04:00
|
|
|
void RenderingManager::configureFog(ESMS::CellStore<MWWorld::RefData> &mCell)
|
|
|
|
{
|
2012-04-05 11:52:06 +02:00
|
|
|
Ogre::ColourValue color;
|
|
|
|
color.setAsABGR (mCell.cell->ambi.fog);
|
2011-11-03 23:47:15 -04:00
|
|
|
|
2012-04-05 11:52:06 +02:00
|
|
|
configureFog(mCell.cell->ambi.fogDensity, color);
|
2012-02-26 13:13:29 +01:00
|
|
|
}
|
2011-11-03 23:47:15 -04:00
|
|
|
|
2012-02-26 13:13:29 +01:00
|
|
|
void RenderingManager::configureFog(const float density, const Ogre::ColourValue& colour)
|
2012-03-08 10:46:34 +04:00
|
|
|
{
|
2012-04-05 11:52:06 +02:00
|
|
|
float max = Settings::Manager::getFloat("max viewing distance", "Viewing distance");
|
2012-03-13 22:14:35 +01:00
|
|
|
|
2012-04-05 11:52:06 +02:00
|
|
|
float low = max / (density) * Settings::Manager::getFloat("fog start factor", "Viewing distance");
|
|
|
|
float high = max / (density) * Settings::Manager::getFloat("fog end factor", "Viewing distance");
|
2012-03-13 22:14:35 +01:00
|
|
|
|
2012-04-05 11:52:06 +02:00
|
|
|
mRendering.getScene()->setFog (FOG_LINEAR, colour, 0, low, high);
|
2012-03-08 10:46:34 +04:00
|
|
|
|
2012-04-05 11:52:06 +02:00
|
|
|
mRendering.getCamera()->setFarClipDistance ( max / density );
|
|
|
|
mRendering.getViewport()->setBackgroundColour (colour);
|
|
|
|
|
|
|
|
CompositorInstance* inst = CompositorManager::getSingleton().getCompositorChain(mRendering.getViewport())->getCompositor("gbuffer");
|
|
|
|
if (inst != 0)
|
|
|
|
inst->getCompositor()->getTechnique(0)->getTargetPass(0)->getPass(0)->setClearColour(colour);
|
2012-04-05 15:30:55 +02:00
|
|
|
if (mWater)
|
|
|
|
mWater->setViewportBackground(colour);
|
2011-11-03 23:47:15 -04:00
|
|
|
}
|
|
|
|
|
2012-02-26 13:13:29 +01:00
|
|
|
|
2011-11-03 23:47:15 -04:00
|
|
|
void RenderingManager::setAmbientMode()
|
|
|
|
{
|
|
|
|
switch (mAmbientMode)
|
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
|
2012-02-28 22:04:44 +01:00
|
|
|
setAmbientColour(mAmbientColor);
|
2011-11-03 23:47:15 -04:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
2012-02-28 22:04:44 +01:00
|
|
|
setAmbientColour(0.7f*mAmbientColor + 0.3f*ColourValue(1,1,1));
|
2011-11-03 23:47:15 -04:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
|
2012-02-28 22:04:44 +01:00
|
|
|
setAmbientColour(ColourValue(1,1,1));
|
2011-11-03 23:47:15 -04:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void RenderingManager::configureAmbient(ESMS::CellStore<MWWorld::RefData> &mCell)
|
|
|
|
{
|
2012-04-05 11:52:06 +02:00
|
|
|
mAmbientColor.setAsABGR (mCell.cell->ambi.ambient);
|
|
|
|
setAmbientMode();
|
2011-11-03 23:47:15 -04:00
|
|
|
|
2012-04-05 11:52:06 +02:00
|
|
|
// Create a "sun" that shines light downwards. It doesn't look
|
|
|
|
// completely right, but leave it for now.
|
|
|
|
if(!mSun)
|
|
|
|
{
|
|
|
|
mSun = mRendering.getScene()->createLight();
|
|
|
|
}
|
|
|
|
Ogre::ColourValue colour;
|
|
|
|
colour.setAsABGR (mCell.cell->ambi.sunlight);
|
|
|
|
mSun->setDiffuseColour (colour);
|
|
|
|
mSun->setType(Ogre::Light::LT_DIRECTIONAL);
|
|
|
|
mSun->setDirection(0,-1,0);
|
2011-11-03 23:47:15 -04:00
|
|
|
}
|
|
|
|
// Switch through lighting modes.
|
|
|
|
|
|
|
|
void RenderingManager::toggleLight()
|
|
|
|
{
|
2012-04-05 11:52:06 +02:00
|
|
|
if (mAmbientMode==2)
|
|
|
|
mAmbientMode = 0;
|
|
|
|
else
|
|
|
|
++mAmbientMode;
|
2011-11-03 23:47:15 -04:00
|
|
|
|
2012-04-05 11:52:06 +02:00
|
|
|
switch (mAmbientMode)
|
|
|
|
{
|
|
|
|
case 0: std::cout << "Setting lights to normal\n"; break;
|
|
|
|
case 1: std::cout << "Turning the lights up\n"; break;
|
|
|
|
case 2: std::cout << "Turning the lights to full\n"; break;
|
|
|
|
}
|
2011-11-03 23:47:15 -04:00
|
|
|
|
2012-04-05 11:52:06 +02:00
|
|
|
setAmbientMode();
|
2011-11-03 23:47:15 -04:00
|
|
|
}
|
2012-04-05 11:52:06 +02:00
|
|
|
void RenderingManager::checkUnderwater()
|
|
|
|
{
|
|
|
|
if(mWater)
|
|
|
|
{
|
2012-03-29 05:03:34 +02:00
|
|
|
mWater->checkUnderwater( mRendering.getCamera()->getRealPosition().y );
|
2012-01-19 23:29:07 -05:00
|
|
|
}
|
2012-01-18 22:42:07 -05:00
|
|
|
}
|
2011-11-03 23:47:15 -04:00
|
|
|
|
2011-11-21 14:08:44 +01:00
|
|
|
void RenderingManager::playAnimationGroup (const MWWorld::Ptr& ptr, const std::string& groupName,
|
|
|
|
int mode, int number)
|
|
|
|
{
|
2011-12-26 19:23:46 -05:00
|
|
|
mActors.playAnimationGroup(ptr, groupName, mode, number);
|
2011-11-21 14:08:44 +01:00
|
|
|
}
|
2011-11-17 17:10:27 -05:00
|
|
|
|
2011-11-21 14:08:44 +01:00
|
|
|
void RenderingManager::skipAnimation (const MWWorld::Ptr& ptr)
|
|
|
|
{
|
2011-12-28 21:52:05 -05:00
|
|
|
mActors.skipAnimation(ptr);
|
2011-11-21 14:08:44 +01:00
|
|
|
}
|
2011-11-17 17:10:27 -05:00
|
|
|
|
2012-02-23 20:33:34 +01:00
|
|
|
void RenderingManager::setSunColour(const Ogre::ColourValue& colour)
|
|
|
|
{
|
2012-04-11 18:53:13 +02:00
|
|
|
if (!mSunEnabled) return;
|
2012-02-23 20:33:34 +01:00
|
|
|
mSun->setDiffuseColour(colour);
|
2012-04-06 14:07:52 +02:00
|
|
|
mSun->setSpecularColour(colour);
|
2012-02-28 22:04:44 +01:00
|
|
|
mTerrainManager->setDiffuse(colour);
|
2012-02-23 20:33:34 +01:00
|
|
|
}
|
2012-02-23 21:12:06 +01:00
|
|
|
|
|
|
|
void RenderingManager::setAmbientColour(const Ogre::ColourValue& colour)
|
|
|
|
{
|
|
|
|
mRendering.getScene()->setAmbientLight(colour);
|
2012-02-28 22:04:44 +01:00
|
|
|
mTerrainManager->setAmbient(colour);
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
2012-02-23 21:12:06 +01:00
|
|
|
|
2012-02-23 20:33:34 +01:00
|
|
|
void RenderingManager::sunEnable()
|
|
|
|
{
|
2012-04-11 18:53:13 +02:00
|
|
|
// Don't disable the light, as the shaders assume the first light to be directional.
|
|
|
|
//if (mSun) mSun->setVisible(true);
|
|
|
|
mSunEnabled = true;
|
2012-02-23 20:33:34 +01:00
|
|
|
}
|
2012-02-23 21:12:06 +01:00
|
|
|
|
2012-02-23 20:33:34 +01:00
|
|
|
void RenderingManager::sunDisable()
|
|
|
|
{
|
2012-04-11 18:53:13 +02:00
|
|
|
// Don't disable the light, as the shaders assume the first light to be directional.
|
|
|
|
//if (mSun) mSun->setVisible(false);
|
|
|
|
mSunEnabled = false;
|
|
|
|
if (mSun)
|
|
|
|
{
|
|
|
|
mSun->setDiffuseColour(ColourValue(0,0,0));
|
|
|
|
mSun->setSpecularColour(ColourValue(0,0,0));
|
|
|
|
}
|
2011-10-20 15:02:19 -04:00
|
|
|
}
|
2012-02-23 20:33:34 +01:00
|
|
|
|
|
|
|
void RenderingManager::setSunDirection(const Ogre::Vector3& direction)
|
|
|
|
{
|
2012-03-08 10:46:34 +04:00
|
|
|
// direction * -1 (because 'direction' is camera to sun vector and not sun to camera),
|
2012-02-28 20:28:46 +01:00
|
|
|
// then convert from MW to ogre coordinates (swap y,z and make y negative)
|
|
|
|
if (mSun) mSun->setDirection(Vector3(-direction.x, -direction.z, direction.y));
|
2012-03-08 10:46:34 +04:00
|
|
|
|
2012-02-24 18:30:16 +01:00
|
|
|
mSkyManager->setSunDirection(direction);
|
2012-02-23 20:33:34 +01:00
|
|
|
}
|
|
|
|
|
2012-02-24 16:12:43 +01:00
|
|
|
void RenderingManager::setGlare(bool glare)
|
|
|
|
{
|
|
|
|
mSkyManager->setGlare(glare);
|
|
|
|
}
|
|
|
|
|
2012-03-10 15:28:18 +01:00
|
|
|
void RenderingManager::requestMap(MWWorld::Ptr::CellStore* cell)
|
|
|
|
{
|
|
|
|
if (!(cell->cell->data.flags & ESM::Cell::Interior))
|
|
|
|
mLocalMap->requestMap(cell);
|
|
|
|
else
|
|
|
|
mLocalMap->requestMap(cell, mObjects.getDimensions(cell));
|
|
|
|
}
|
|
|
|
|
2012-03-14 20:44:06 +01:00
|
|
|
void RenderingManager::preCellChange(MWWorld::Ptr::CellStore* cell)
|
|
|
|
{
|
|
|
|
mLocalMap->saveFogOfWar(cell);
|
|
|
|
}
|
|
|
|
|
2012-04-02 19:37:24 +02:00
|
|
|
void RenderingManager::disableLights()
|
|
|
|
{
|
|
|
|
mObjects.disableLights();
|
2012-04-14 15:58:58 +02:00
|
|
|
sunDisable();
|
2012-04-02 19:37:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void RenderingManager::enableLights()
|
|
|
|
{
|
|
|
|
mObjects.enableLights();
|
2012-04-14 15:58:58 +02:00
|
|
|
sunEnable();
|
2012-04-02 19:37:24 +02:00
|
|
|
}
|
|
|
|
|
2012-04-05 19:27:54 +02:00
|
|
|
const bool RenderingManager::useMRT()
|
|
|
|
{
|
|
|
|
return Settings::Manager::getBool("shader", "Water");
|
|
|
|
}
|
|
|
|
|
2012-04-11 18:53:13 +02:00
|
|
|
Shadows* RenderingManager::getShadows()
|
|
|
|
{
|
|
|
|
return mShadows;
|
|
|
|
}
|
|
|
|
|
2012-02-23 20:33:34 +01:00
|
|
|
} // namespace
|