1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-22 04:53:51 +00:00
openmw-tes3mp/apps/openmw/mwrender/actors.cpp

193 lines
5.1 KiB
C++
Raw Normal View History

2011-11-25 04:13:34 +00:00
#include "actors.hpp"
2011-12-14 04:49:03 +00:00
#include <OgreSceneNode.h>
#include <OgreSceneManager.h>
2011-11-25 04:13:34 +00:00
#include "../mwworld/ptr.hpp"
#include "../mwworld/class.hpp"
2013-02-27 08:20:42 +00:00
#include "../mwrender/renderingmanager.hpp"
#include "animation.hpp"
#include "activatoranimation.hpp"
#include "creatureanimation.hpp"
#include "npcanimation.hpp"
2012-09-13 17:03:31 +00:00
#include "renderconst.hpp"
namespace MWRender
{
2011-11-25 04:13:34 +00:00
using namespace Ogre;
Actors::~Actors()
{
PtrAnimationMap::iterator it = mAllActors.begin();
for(;it != mAllActors.end();++it)
{
delete it->second;
it->second = NULL;
}
}
2013-02-26 13:01:10 +00:00
void Actors::setRootNode(Ogre::SceneNode* root)
{ mRootNode = root; }
void Actors::insertBegin(const MWWorld::Ptr &ptr)
{
2011-11-25 04:13:34 +00:00
Ogre::SceneNode* cellnode;
CellSceneNodeMap::const_iterator celliter = mCellSceneNodes.find(ptr.getCell());
if(celliter != mCellSceneNodes.end())
cellnode = celliter->second;
else
2011-11-25 04:13:34 +00:00
{
//Create the scenenode and put it in the map
2013-02-26 13:01:10 +00:00
cellnode = mRootNode->createChildSceneNode();
2011-11-25 04:13:34 +00:00
mCellSceneNodes[ptr.getCell()] = cellnode;
}
Ogre::SceneNode* insert = cellnode->createChildSceneNode();
const float *f = ptr.getRefData().getPosition().pos;
insert->setPosition(f[0], f[1], f[2]);
insert->setScale(ptr.getCellRef().getScale(), ptr.getCellRef().getScale(), ptr.getCellRef().getScale());
2011-11-25 04:13:34 +00:00
// Convert MW rotation to a quaternion:
f = ptr.getCellRef().getPosition().rot;
2011-11-25 04:13:34 +00:00
// For rendering purposes, actors should only rotate around the Z axis.
// X rotation is used for camera rotation (for the player) and for
// ranged magic / ranged weapon aiming.
Ogre::Quaternion zr(Ogre::Radian(-f[2]), Ogre::Vector3::UNIT_Z);
2011-11-25 04:13:34 +00:00
insert->setOrientation(zr);
2011-11-25 04:13:34 +00:00
ptr.getRefData().setBaseNode(insert);
2011-12-09 05:08:30 +00:00
}
void Actors::insertNPC(const MWWorld::Ptr& ptr)
{
insertBegin(ptr);
NpcAnimation* anim = new NpcAnimation(ptr, ptr.getRefData().getBaseNode(), RV_Actors);
delete mAllActors[ptr];
mAllActors[ptr] = anim;
2013-02-27 08:20:42 +00:00
mRendering->addWaterRippleEmitter (ptr);
}
void Actors::insertCreature (const MWWorld::Ptr& ptr, bool weaponsShields)
{
insertBegin(ptr);
Animation* anim = NULL;
if (weaponsShields)
anim = new CreatureWeaponAnimation(ptr);
else
anim = new CreatureAnimation(ptr);
delete mAllActors[ptr];
2011-12-25 02:53:12 +00:00
mAllActors[ptr] = anim;
2013-02-27 08:20:42 +00:00
mRendering->addWaterRippleEmitter (ptr);
2011-11-25 04:13:34 +00:00
}
void Actors::insertActivator (const MWWorld::Ptr& ptr)
{
insertBegin(ptr);
ActivatorAnimation* anim = new ActivatorAnimation(ptr);
delete mAllActors[ptr];
mAllActors[ptr] = anim;
}
2011-11-25 04:13:34 +00:00
bool Actors::deleteObject (const MWWorld::Ptr& ptr)
{
if (mAllActors.find(ptr) == mAllActors.end())
return false;
2013-02-27 08:20:42 +00:00
mRendering->removeWaterRippleEmitter (ptr);
delete mAllActors[ptr];
mAllActors.erase(ptr);
if(Ogre::SceneNode *base=ptr.getRefData().getBaseNode())
{
2011-11-25 04:13:34 +00:00
Ogre::SceneNode *parent = base->getParentSceneNode();
CellSceneNodeMap::const_iterator iter(mCellSceneNodes.begin());
for(;iter != mCellSceneNodes.end();++iter)
{
if(iter->second == parent)
2011-11-25 04:13:34 +00:00
{
base->removeAndDestroyAllChildren();
mRend.getScene()->destroySceneNode (base);
ptr.getRefData().setBaseNode (0);
return true;
}
}
2011-11-25 04:13:34 +00:00
return false;
}
return true;
}
void Actors::removeCell(MWWorld::CellStore* store)
{
for(PtrAnimationMap::iterator iter = mAllActors.begin();iter != mAllActors.end();)
2012-02-26 22:31:16 +00:00
{
if(iter->first.getCell() == store)
{
2013-02-27 08:20:42 +00:00
mRendering->removeWaterRippleEmitter (iter->first);
2012-02-26 22:31:16 +00:00
delete iter->second;
mAllActors.erase(iter++);
}
2012-02-26 21:45:17 +00:00
else
++iter;
2012-02-26 22:31:16 +00:00
}
CellSceneNodeMap::iterator celliter = mCellSceneNodes.find(store);
if(celliter != mCellSceneNodes.end())
{
Ogre::SceneNode *base = celliter->second;
base->removeAndDestroyAllChildren();
mRend.getScene()->destroySceneNode(base);
mCellSceneNodes.erase(celliter);
}
2011-12-27 00:23:46 +00:00
}
void Actors::update (Ogre::Camera* camera)
{
for(PtrAnimationMap::iterator iter = mAllActors.begin();iter != mAllActors.end(); ++iter)
{
iter->second->preRender(camera);
}
2011-12-27 00:23:46 +00:00
}
2012-07-30 19:28:14 +00:00
Animation* Actors::getAnimation(const MWWorld::Ptr &ptr)
{
PtrAnimationMap::const_iterator iter = mAllActors.find(ptr);
if(iter != mAllActors.end())
return iter->second;
return NULL;
}
void Actors::updateObjectCell(const MWWorld::Ptr &old, const MWWorld::Ptr &cur)
2012-07-30 19:28:14 +00:00
{
Ogre::SceneNode *node;
MWWorld::CellStore *newCell = cur.getCell();
2012-07-30 19:28:14 +00:00
CellSceneNodeMap::const_iterator celliter = mCellSceneNodes.find(newCell);
if(celliter != mCellSceneNodes.end())
node = celliter->second;
else
{
2013-02-26 13:01:10 +00:00
node = mRootNode->createChildSceneNode();
2012-07-30 19:28:14 +00:00
mCellSceneNodes[newCell] = node;
}
node->addChild(cur.getRefData().getBaseNode());
PtrAnimationMap::iterator iter = mAllActors.find(old);
if(iter != mAllActors.end())
{
Animation *anim = iter->second;
mAllActors.erase(iter);
anim->updatePtr(cur);
mAllActors[cur] = anim;
2012-07-30 19:28:14 +00:00
}
2013-02-27 08:20:42 +00:00
mRendering->updateWaterRippleEmitterPtr (old, cur);
2012-07-30 19:28:14 +00:00
}
}