2011-10-25 14:06:44 -04:00
|
|
|
#include "debugging.hpp"
|
2010-06-05 20:37:01 +02:00
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
|
2010-06-06 13:36:45 +02:00
|
|
|
#include "OgreRoot.h"
|
|
|
|
#include "OgreRenderWindow.h"
|
|
|
|
#include "OgreSceneManager.h"
|
|
|
|
#include "OgreViewport.h"
|
|
|
|
#include "OgreCamera.h"
|
|
|
|
#include "OgreTextureManager.h"
|
|
|
|
|
2010-08-25 09:19:15 +02:00
|
|
|
#include "../mwworld/world.hpp" // these includes can be removed once the static-hack is gone
|
2012-03-10 20:45:55 +04:00
|
|
|
#include "../mwworld/environment.hpp"
|
2010-08-25 09:19:15 +02:00
|
|
|
#include "../mwworld/ptr.hpp"
|
|
|
|
#include <components/esm/loadstat.hpp>
|
2012-03-08 10:46:34 +04:00
|
|
|
#include <components/esm/loadpgrd.hpp>
|
2010-08-25 09:19:15 +02:00
|
|
|
|
2011-01-08 15:11:37 +01:00
|
|
|
#include "player.hpp"
|
|
|
|
|
2010-06-08 13:53:34 +02:00
|
|
|
using namespace MWRender;
|
2010-06-05 20:37:01 +02:00
|
|
|
using namespace Ogre;
|
|
|
|
|
2012-03-10 20:45:55 +04:00
|
|
|
Debugging::Debugging(MWWorld::Environment &env, SceneManager* sceneMgr, OEngine::Physic::PhysicEngine *engine) :
|
|
|
|
mEnvironment(env), mSceneMgr(sceneMgr), mEngine(engine), pathgridEnabled(false)
|
2012-03-08 10:46:34 +04:00
|
|
|
{
|
2011-10-22 00:15:15 -04:00
|
|
|
}
|
|
|
|
|
2011-10-24 13:42:36 -04:00
|
|
|
|
2011-10-22 00:15:15 -04:00
|
|
|
bool Debugging::toggleRenderMode (int mode){
|
2012-03-08 10:46:34 +04:00
|
|
|
switch (mode)
|
2011-10-22 00:15:15 -04:00
|
|
|
{
|
|
|
|
case MWWorld::World::Render_CollisionDebug:
|
|
|
|
|
|
|
|
// TODO use a proper function instead of accessing the member variable
|
|
|
|
// directly.
|
2012-03-08 10:46:34 +04:00
|
|
|
mEngine->setDebugRenderingMode (!mEngine->isDebugCreated);
|
|
|
|
return mEngine->isDebugCreated;
|
|
|
|
case MWWorld::World::Render_Pathgrid:
|
|
|
|
togglePathgrid();
|
|
|
|
return pathgridEnabled;
|
2011-10-22 00:15:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2012-03-08 10:46:34 +04:00
|
|
|
|
|
|
|
void Debugging::cellAdded(MWWorld::Ptr::CellStore *store)
|
|
|
|
{
|
|
|
|
std::cout << "Cell added to debugging" << std::endl;
|
|
|
|
mActiveCells.push_back(store);
|
|
|
|
if (pathgridEnabled)
|
|
|
|
togglePathgridForCell(store, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Debugging::cellRemoved(MWWorld::Ptr::CellStore *store)
|
|
|
|
{
|
|
|
|
mActiveCells.erase(std::remove(mActiveCells.begin(), mActiveCells.end(), store), mActiveCells.end());
|
|
|
|
std::cout << "Cell removed from debugging, active cells count: " << mActiveCells.size() << std::endl;
|
|
|
|
if (pathgridEnabled)
|
|
|
|
togglePathgridForCell(store, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Debugging::togglePathgrid()
|
|
|
|
{
|
|
|
|
pathgridEnabled = !pathgridEnabled;
|
|
|
|
if (pathgridEnabled)
|
|
|
|
{
|
|
|
|
// add path grid meshes to already loaded cells
|
|
|
|
mPathGridRoot = mSceneMgr->getRootSceneNode()->createChildSceneNode();
|
|
|
|
for(CellList::iterator it = mActiveCells.begin(); it != mActiveCells.end(); it++)
|
|
|
|
{
|
|
|
|
togglePathgridForCell(*it, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// remove path grid meshes from already loaded cells
|
|
|
|
for(CellList::iterator it = mActiveCells.begin(); it != mActiveCells.end(); it++)
|
|
|
|
{
|
|
|
|
togglePathgridForCell(*it, false);
|
|
|
|
}
|
|
|
|
mPathGridRoot->removeAndDestroyAllChildren();
|
|
|
|
mSceneMgr->destroySceneNode(mPathGridRoot);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Debugging::togglePathgridForCell(MWWorld::Ptr::CellStore *store, bool enabled)
|
|
|
|
{
|
2012-03-10 20:45:55 +04:00
|
|
|
ESM::Pathgrid *pathgrid = mEnvironment.mWorld->getStore().pathgrids.search(*store->cell);
|
2012-03-08 10:46:34 +04:00
|
|
|
if (!pathgrid)
|
|
|
|
{
|
|
|
|
std::cout << "No path grid :(" << std::endl;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
std::cout << "Path grid exists!" << std::endl;
|
|
|
|
|
|
|
|
if (enabled)
|
|
|
|
{
|
|
|
|
Vector3 cellPathGridPos;
|
|
|
|
if (!(store->cell->data.flags & ESM::Cell::Interior))
|
|
|
|
{
|
|
|
|
/// \todo Replace with ESM::Land::REAL_SIZE after merging with terrain branch
|
|
|
|
cellPathGridPos.x = store->cell->data.gridX * 8192;
|
|
|
|
cellPathGridPos.z = -store->cell->data.gridY * 8192;
|
|
|
|
}
|
|
|
|
SceneNode *cellPathGrid = mPathGridRoot->createChildSceneNode(cellPathGridPos);
|
|
|
|
ESM::Pathgrid::PointList points = pathgrid->points;
|
|
|
|
for (ESM::Pathgrid::PointList::iterator it = points.begin(); it != points.end(); it++)
|
|
|
|
{
|
|
|
|
Vector3 position(it->x, it->z, -it->y);
|
|
|
|
SceneNode* pointNode = cellPathGrid->createChildSceneNode(position);
|
|
|
|
pointNode->setScale(0.5, 0.5, 0.5);
|
|
|
|
Entity *pointMesh = mSceneMgr->createEntity(SceneManager::PT_CUBE);
|
|
|
|
pointNode->attachObject(pointMesh);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(store->cell->data.flags & ESM::Cell::Interior))
|
|
|
|
{
|
|
|
|
mExteriorPathgridNodes[std::make_pair(store->cell->data.gridX, store->cell->data.gridY)] = cellPathGrid;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
assert(mInteriorPathgridNode == NULL);
|
|
|
|
mInteriorPathgridNode = cellPathGrid;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/// \todo Don't forget to destroy cubes too!
|
|
|
|
SceneNode *cellPathGridNode;
|
|
|
|
if (!(store->cell->data.flags & ESM::Cell::Interior))
|
|
|
|
{
|
|
|
|
ExteriorPathgridNodes::iterator it =
|
|
|
|
mExteriorPathgridNodes.find(std::make_pair(store->cell->data.gridX, store->cell->data.gridY));
|
|
|
|
if (it != mExteriorPathgridNodes.end())
|
|
|
|
{
|
|
|
|
cellPathGridNode = it->second;
|
|
|
|
mPathGridRoot->removeChild(cellPathGridNode);
|
|
|
|
cellPathGridNode->removeAndDestroyAllChildren();
|
|
|
|
mSceneMgr->destroySceneNode(cellPathGridNode);
|
|
|
|
mExteriorPathgridNodes.erase(it);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (mInteriorPathgridNode)
|
|
|
|
{
|
|
|
|
mPathGridRoot->removeChild(mInteriorPathgridNode);
|
|
|
|
mInteriorPathgridNode->removeAndDestroyAllChildren();
|
|
|
|
mSceneMgr->destroySceneNode(mInteriorPathgridNode);
|
|
|
|
mInteriorPathgridNode = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|