mirror of
https://github.com/OpenMW/openmw.git
synced 2025-02-03 18:45:34 +00:00
Offset animation times to start at 0
This commit is contained in:
parent
1e38e381a4
commit
465fd9c8af
1 changed files with 7 additions and 3 deletions
|
@ -164,7 +164,7 @@ static void fail(const std::string &msg)
|
||||||
|
|
||||||
static void buildAnimation(Ogre::Skeleton *skel, const std::string &name, const std::vector<Nif::NiKeyframeController*> &ctrls, const std::vector<std::string> &targets, float startTime, float stopTime)
|
static void buildAnimation(Ogre::Skeleton *skel, const std::string &name, const std::vector<Nif::NiKeyframeController*> &ctrls, const std::vector<std::string> &targets, float startTime, float stopTime)
|
||||||
{
|
{
|
||||||
Ogre::Animation *anim = skel->createAnimation(name, stopTime);
|
Ogre::Animation *anim = skel->createAnimation(name, stopTime-startTime);
|
||||||
|
|
||||||
for(size_t i = 0;i < ctrls.size();i++)
|
for(size_t i = 0;i < ctrls.size();i++)
|
||||||
{
|
{
|
||||||
|
@ -246,7 +246,7 @@ static void buildAnimation(Ogre::Skeleton *skel, const std::string &name, const
|
||||||
}
|
}
|
||||||
|
|
||||||
Ogre::TransformKeyFrame *kframe;
|
Ogre::TransformKeyFrame *kframe;
|
||||||
kframe = nodetrack->createNodeKeyFrame(curtime);
|
kframe = nodetrack->createNodeKeyFrame(curtime-startTime);
|
||||||
if(quatiter == quatkeys.mKeys.end() || quatiter == quatkeys.mKeys.begin())
|
if(quatiter == quatkeys.mKeys.end() || quatiter == quatkeys.mKeys.begin())
|
||||||
kframe->setRotation(curquat);
|
kframe->setRotation(curquat);
|
||||||
else
|
else
|
||||||
|
@ -450,8 +450,12 @@ void loadResource(Ogre::Resource *resource)
|
||||||
|
|
||||||
buildAnimation(skel, currentgroup, ctrls, targets, keyiter->first, lastkeyiter->first);
|
buildAnimation(skel, currentgroup, ctrls, targets, keyiter->first, lastkeyiter->first);
|
||||||
|
|
||||||
|
TextKeyMap::const_iterator insiter = keyiter;
|
||||||
TextKeyMap groupkeys;
|
TextKeyMap groupkeys;
|
||||||
groupkeys.insert(keyiter, ++lastkeyiter);
|
do {
|
||||||
|
groupkeys.insert(std::make_pair(insiter->first - keyiter->first, insiter->second));
|
||||||
|
} while(insiter++ != lastkeyiter);
|
||||||
|
|
||||||
Ogre::UserObjectBindings &bindings = boneiter.peekNext()->getUserObjectBindings();
|
Ogre::UserObjectBindings &bindings = boneiter.peekNext()->getUserObjectBindings();
|
||||||
bindings.setUserAny(std::string(sTextKeyExtraDataID)+"@"+currentgroup, Ogre::Any(groupkeys));
|
bindings.setUserAny(std::string(sTextKeyExtraDataID)+"@"+currentgroup, Ogre::Any(groupkeys));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue