mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 09:35:28 +00:00
commit
99ab629a03
@ -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);
|
||||
|
@ -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
|
||||
|
@ -208,6 +208,12 @@ bool CreatureWeaponAnimation::isArrowAttached() const
|
||||
return mAmmunition != nullptr;
|
||||
}
|
||||
|
||||
void CreatureWeaponAnimation::detachArrow()
|
||||
{
|
||||
WeaponAnimation::detachArrow(mPtr);
|
||||
updateQuiver();
|
||||
}
|
||||
|
||||
void CreatureWeaponAnimation::attachArrow()
|
||||
{
|
||||
WeaponAnimation::attachArrow(mPtr);
|
||||
|
@ -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();
|
||||
|
@ -363,6 +363,7 @@ void NpcAnimation::setViewMode(NpcAnimation::ViewMode viewMode)
|
||||
mViewMode = viewMode;
|
||||
MWBase::Environment::get().getWorld()->scaleObject(mPtr, mPtr.getCellRef().getScale()); // apply race height after view change
|
||||
|
||||
mAmmunition.reset();
|
||||
rebuild();
|
||||
setRenderBin();
|
||||
}
|
||||
@ -1051,6 +1052,12 @@ void NpcAnimation::attachArrow()
|
||||
updateQuiver();
|
||||
}
|
||||
|
||||
void NpcAnimation::detachArrow()
|
||||
{
|
||||
WeaponAnimation::detachArrow(mPtr);
|
||||
updateQuiver();
|
||||
}
|
||||
|
||||
void NpcAnimation::releaseArrow(float attackStrength)
|
||||
{
|
||||
WeaponAnimation::releaseArrow(mPtr, attackStrength);
|
||||
|
@ -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();
|
||||
|
@ -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);
|
||||
|
@ -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);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user