1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-20 13:23:52 +00:00

Reset attached arrow in the beginning of unequipping animation

This commit is contained in:
Andrei Kortunov 2020-08-28 15:28:26 +04:00
parent 7ee5526dbf
commit 297898182b
8 changed files with 24 additions and 0 deletions

View file

@ -1306,6 +1306,8 @@ bool CharacterController::updateWeaponState(CharacterState& idle)
1.0f, "unequip start", "unequip stop", 0.0f, 0);
mUpperBodyState = UpperCharState_UnEquipingWeap;
mAnimation->detachArrow();
// If we do not have the "unequip detach" key, hide weapon manually.
if (mAnimation->getTextKeyTime(weapgroup+": unequip detach") < 0)
mAnimation->showWeapons(false);

View file

@ -474,6 +474,7 @@ public:
void setAlpha(float alpha);
virtual void setPitchFactor(float factor) {}
virtual void attachArrow() {}
virtual void detachArrow() {}
virtual void releaseArrow(float attackStrength) {}
virtual void enableHeadAnimation(bool enable) {}
// TODO: move outside of this class

View file

@ -208,6 +208,12 @@ bool CreatureWeaponAnimation::isArrowAttached() const
return mAmmunition != nullptr;
}
void CreatureWeaponAnimation::detachArrow()
{
WeaponAnimation::detachArrow(mPtr);
updateQuiver();
}
void CreatureWeaponAnimation::attachArrow()
{
WeaponAnimation::attachArrow(mPtr);

View file

@ -40,6 +40,7 @@ namespace MWRender
void updatePart(PartHolderPtr& scene, int slot);
virtual void attachArrow();
virtual void detachArrow();
virtual void releaseArrow(float attackStrength);
// WeaponAnimation
virtual osg::Group* getArrowBone();

View file

@ -1051,6 +1051,12 @@ void NpcAnimation::attachArrow()
updateQuiver();
}
void NpcAnimation::detachArrow()
{
WeaponAnimation::detachArrow(mPtr);
updateQuiver();
}
void NpcAnimation::releaseArrow(float attackStrength)
{
WeaponAnimation::releaseArrow(mPtr, attackStrength);

View file

@ -142,6 +142,7 @@ public:
virtual void showCarriedLeft(bool show);
virtual void attachArrow();
virtual void detachArrow();
virtual void releaseArrow(float attackStrength);
virtual osg::Group* getArrowBone();

View file

@ -98,6 +98,11 @@ void WeaponAnimation::attachArrow(MWWorld::Ptr actor)
}
}
void WeaponAnimation::detachArrow(MWWorld::Ptr actor)
{
mAmmunition.reset();
}
void WeaponAnimation::releaseArrow(MWWorld::Ptr actor, float attackStrength)
{
MWWorld::InventoryStore& inv = actor.getClass().getInventoryStore(actor);

View file

@ -36,6 +36,8 @@ namespace MWRender
/// @note If no weapon (or an invalid weapon) is equipped, this function is a no-op.
void attachArrow(MWWorld::Ptr actor);
void detachArrow(MWWorld::Ptr actor);
/// @note If no weapon (or an invalid weapon) is equipped, this function is a no-op.
void releaseArrow(MWWorld::Ptr actor, float attackStrength);