1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 06:35:30 +00:00
OpenMW/apps/openmw/mwrender/creatureanimation.cpp

66 lines
2.0 KiB
C++
Raw Normal View History

#include "creatureanimation.hpp"
2012-04-03 15:13:47 +02:00
#include "renderconst.hpp"
#include "../mwworld/world.hpp"
using namespace Ogre;
using namespace NifOgre;
namespace MWRender{
2011-12-11 23:42:39 -05:00
CreatureAnimation::~CreatureAnimation(){
}
CreatureAnimation::CreatureAnimation(const MWWorld::Ptr& ptr, MWWorld::Environment& _env,OEngine::Render::OgreRenderer& _rend): Animation(_env,_rend){
2012-01-05 21:45:17 -05:00
insert = ptr.getRefData().getBaseNode();
ESMS::LiveCellRef<ESM::Creature, MWWorld::RefData> *ref =
ptr.get<ESM::Creature>();
2012-01-17 15:10:53 +01:00
assert (ref->base != NULL);
if(!ref->base->model.empty()){
const std::string &mesh = "meshes\\" + ref->base->model;
std::string meshNumbered = mesh + getUniqueID(mesh) + ">|";
NifOgre::NIFLoader::load(meshNumbered);
base = mRend.getScene()->createEntity(meshNumbered);
2012-04-03 15:13:47 +02:00
base->setVisibilityFlags(RV_Actors);
std::string meshZero = mesh + "0000>|";
2012-01-17 15:10:53 +01:00
if((transformations = (NIFLoader::getSingletonPtr())->getAnim(meshZero))){
2011-12-15 00:33:10 -05:00
2012-01-17 15:10:53 +01:00
for(std::size_t init = 0; init < transformations->size(); init++){
2011-12-15 00:33:10 -05:00
rindexI.push_back(0);
tindexI.push_back(0);
}
stopTime = transformations->begin()->getStopTime();
2012-01-05 21:45:17 -05:00
startTime = transformations->begin()->getStartTime();
shapes = (NIFLoader::getSingletonPtr())->getShapes(meshZero);
2012-01-06 00:55:02 -05:00
}
textmappings = NIFLoader::getSingletonPtr()->getTextIndices(meshZero);
insert->attachObject(base);
}
}
void CreatureAnimation::runAnimation(float timepassed){
vecRotPos.clear();
if(animate > 0){
//Add the amount of time passed to time
//Handle the animation transforms dependent on time
//Handle the shapes dependent on animation transforms
2011-12-26 19:23:46 -05:00
time += timepassed;
2012-01-10 02:00:04 -05:00
if(time >= stopTime){
animate--;
//std::cout << "Stopping the animation\n";
if(animate == 0)
time = stopTime;
else
time = startTime + (time - stopTime);
2011-12-28 17:34:47 -05:00
}
2012-01-17 15:10:53 +01:00
2011-12-27 22:35:22 -05:00
handleAnimationTransforms();
2011-12-27 00:20:14 -05:00
handleShapes(shapes, base, base->getSkeleton());
}
}
2012-01-17 15:10:53 +01:00
}