openmw-tes3coop/apps/openmw/mwrender/creatureanimation.cpp

83 lines
2.4 KiB
C++
Raw Normal View History

#include "creatureanimation.hpp"
#include <OgreEntity.h>
#include <OgreSceneManager.h>
#include <OgreSubEntity.h>
2012-04-03 13:13:47 +00:00
#include "renderconst.hpp"
#include "../mwbase/world.hpp"
using namespace Ogre;
using namespace NifOgre;
namespace MWRender{
2011-12-12 04:42:39 +00:00
CreatureAnimation::~CreatureAnimation()
{
2011-12-12 04:42:39 +00:00
}
CreatureAnimation::CreatureAnimation(const MWWorld::Ptr& ptr, OEngine::Render::OgreRenderer& _rend): Animation(_rend)
{
mInsert = ptr.getRefData().getBaseNode();
MWWorld::LiveCellRef<ESM::Creature> *ref = ptr.get<ESM::Creature>();
2012-01-17 14:10:53 +00:00
assert (ref->base != NULL);
if(!ref->base->model.empty())
{
std::string mesh = "meshes\\" + ref->base->model;
2012-07-17 23:00:03 +00:00
mEntityList = NifOgre::NIFLoader::createEntities(mInsert, mesh);
for(size_t i = 0;i < mEntityList.mEntities.size();i++)
2012-04-04 16:53:40 +00:00
{
2012-07-17 23:00:03 +00:00
Ogre::Entity *ent = mEntityList.mEntities[i];
ent->setVisibilityFlags(RV_Actors);
2012-07-17 18:23:34 +00:00
bool transparent = false;
2012-07-17 23:00:03 +00:00
for (unsigned int j=0;j < ent->getNumSubEntities() && !transparent; ++j)
2012-04-04 16:53:40 +00:00
{
2012-07-17 23:00:03 +00:00
Ogre::MaterialPtr mat = ent->getSubEntity(j)->getMaterial();
2012-07-17 18:23:34 +00:00
Ogre::Material::TechniqueIterator techIt = mat->getTechniqueIterator();
while (techIt.hasMoreElements() && !transparent)
2012-04-04 16:53:40 +00:00
{
2012-07-17 18:23:34 +00:00
Ogre::Technique* tech = techIt.getNext();
Ogre::Technique::PassIterator passIt = tech->getPassIterator();
while (passIt.hasMoreElements() && !transparent)
{
Ogre::Pass* pass = passIt.getNext();
if (pass->getDepthWriteEnabled() == false)
transparent = true;
}
2012-04-04 16:53:40 +00:00
}
}
2012-07-17 23:00:03 +00:00
ent->setRenderQueueGroup(transparent ? RQG_Alpha : RQG_Main);
2012-07-17 18:23:34 +00:00
}
}
}
void CreatureAnimation::runAnimation(float timepassed)
{
if(mAnimate > 0)
{
//Add the amount of time passed to time
//Handle the animation transforms dependent on time
//Handle the shapes dependent on animation transforms
mTime += timepassed;
if(mTime >= mStopTime)
{
mAnimate--;
//std::cout << "Stopping the animation\n";
if(mAnimate == 0)
mTime = mStopTime;
else
mTime = mStartTime + (mTime - mStopTime);
2011-12-28 22:34:47 +00:00
}
2012-01-17 14:10:53 +00:00
2011-12-28 03:35:22 +00:00
handleAnimationTransforms();
}
}
2012-01-17 14:10:53 +00:00
}