From f7f23ac5d8f3e6c6f541d5f56b66abc9977f4742 Mon Sep 17 00:00:00 2001 From: gus Date: Mon, 15 Jul 2013 17:18:16 +0100 Subject: [PATCH] improvement of the chop animation. Still some jittering. --- apps/openmw/mwmechanics/character.cpp | 50 +++++++++++++++++++++++---- apps/openmw/mwmechanics/character.hpp | 12 +++++-- 2 files changed, 53 insertions(+), 9 deletions(-) diff --git a/apps/openmw/mwmechanics/character.cpp b/apps/openmw/mwmechanics/character.cpp index 35f2ae207b..9bc914ce34 100644 --- a/apps/openmw/mwmechanics/character.cpp +++ b/apps/openmw/mwmechanics/character.cpp @@ -478,17 +478,30 @@ void CharacterController::update(float duration, Movement &movement) if(mUpperBodyState == UpperCharState_WeapEquiped) { std::string weapgroup; - std::cout << "attaquing"; getWeaponGroup(mWeaponType, weapgroup); mAnimation->play(weapgroup, Priority_Weapon, MWRender::Animation::Group_UpperBody, true, - "chop start", "chop large follow stop", 0.0f, 0); - mUpperBodyState = UpperCharState_ChopReadyingMouseHold; + "chop start", "chop min attack", 0.0f, 0); + mUpperBodyState = UpperCharState_ChopStartToMinAttack; } } - else if(mUpperBodyState == UpperCharState_ChopReadyingMouseHold) + else if(mUpperBodyState == UpperCharState_ChopMinAttackToMaxAttack) { - mUpperBodyState = UpperCharState_ChopReadying; + std::string weapgroup; + getWeaponGroup(mWeaponType, weapgroup); + std::string start; + std::string stop; + float complete; + //mAnimation-> + if(mAnimation->getInfo(weapgroup,&complete,&start,&stop)) + { + std::cout << "BLABLABLA"; + mAnimation->disable(weapgroup); + mAnimation->play(weapgroup, Priority_Weapon, + MWRender::Animation::Group_UpperBody, true, + "chop max attack", "chop min hit", 1-complete, 0); + } + mUpperBodyState = UpperCharState_ChopMaxAttackToMinHit; } std::string weapgroup; @@ -499,7 +512,32 @@ void CharacterController::update(float duration, Movement &movement) bool animPlaying = mAnimation->getInfo(weapgroup,&complete,&start,&stop); if(mUpperBodyState == UpperCharState_EquipingWeap && !animPlaying) mUpperBodyState = UpperCharState_WeapEquiped; if(mUpperBodyState == UpperCharState_UnEquipingWeap && !animPlaying) mUpperBodyState = UpperCharState_Nothing; - if(mUpperBodyState == UpperCharState_ChopReadying && !animPlaying) mUpperBodyState = UpperCharState_WeapEquiped; + if(mUpperBodyState == UpperCharState_ChopStartToMinAttack && !animPlaying) + { + mAnimation->play(weapgroup, Priority_Weapon, + MWRender::Animation::Group_UpperBody, true, + "chop min attack", "chop max attack",0, 0); + std::cout << "changing 1"; + mUpperBodyState = UpperCharState_ChopMinAttackToMaxAttack; + } + if(mUpperBodyState == UpperCharState_ChopMaxAttackToMinHit && !animPlaying) + { + mAnimation->play(weapgroup, Priority_Weapon, + MWRender::Animation::Group_UpperBody, true, + "chop min hit", "chop hit",0, 0); + mUpperBodyState = UpperCharState_ChopMinHitToHit; + } + if(mUpperBodyState == UpperCharState_ChopMinHitToHit && !animPlaying) + { + mAnimation->play(weapgroup, Priority_Weapon, + MWRender::Animation::Group_UpperBody, true, + "chop large follow start", "chop large follow stop",0, 0); + mUpperBodyState = UpperCharState_ChopLargeFollowStartToLargeFollowStop; + } + if(mUpperBodyState == UpperCharState_ChopLargeFollowStartToLargeFollowStop && !animPlaying) + { + mUpperBodyState = UpperCharState_WeapEquiped; + } MWWorld::ContainerStoreIterator torch = inv.getSlot(MWWorld::InventoryStore::Slot_CarriedLeft); if(torch != inv.end() && torch->getTypeName() == typeid(ESM::Light).name()) diff --git a/apps/openmw/mwmechanics/character.hpp b/apps/openmw/mwmechanics/character.hpp index ab01038b8c..72768d7e77 100644 --- a/apps/openmw/mwmechanics/character.hpp +++ b/apps/openmw/mwmechanics/character.hpp @@ -98,9 +98,15 @@ enum UpperBodyCharacterState { UpperCharState_UnEquipingWeap, UpperCharState_WeapEquiped, UpperCharState_Slashing, - UpperCharState_ChopReadying, - UpperCharState_ChopReadyingMouseHold, //when you keep your mouse clicked to ready your weapon - UpperCharState_ChopReadyWaiting, //when your weapon is ready and you keep mouse hold + UpperCharState_ChopStartToMinAttack, + UpperCharState_ChopMinAttackToMaxAttack, + UpperCharState_ChopMaxAttackToMinHit, + UpperCharState_ChopMinHitToHit, + UpperCharState_ChopLargeFollowStartToLargeFollowStop, + UpperCharState_ChopMediumFollowStartToMediumFollowStop, + UpperCharState_ChopSmallFollowStartToSmallFollowStop, + //UpperCharState_ChopReadyingMouseHold, //when you keep your mouse clicked to ready your weapon + //UpperCharState_ChopReadyWaiting, //when your weapon is ready and you keep mouse hold UpperCharState_Choping, UpperCharState_Thrusting, UpperCharState_EquipingSpell,