1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-17 10:10:23 +00:00

Merge branch 'imnotyourpalbuddy' into 'master'

Reset friendly hits at the end of combat and don't count hits while in combat

Closes #5755

See merge request OpenMW/openmw!3839
This commit is contained in:
Alexei Kotov 2024-02-09 21:28:04 +00:00
commit a54d97669f
7 changed files with 24 additions and 1 deletions

View File

@ -26,6 +26,7 @@
Bug #5371: Keyframe animation tracks are used for any file that begins with an X Bug #5371: Keyframe animation tracks are used for any file that begins with an X
Bug #5413: Enemies do a battlecry everytime the player summons a creature Bug #5413: Enemies do a battlecry everytime the player summons a creature
Bug #5714: Touch spells cast using ExplodeSpell don't always explode Bug #5714: Touch spells cast using ExplodeSpell don't always explode
Bug #5755: Reset friendly hit counter
Bug #5849: Paralysis breaks landing Bug #5849: Paralysis breaks landing
Bug #5870: Disposing of actors who were selected in the console doesn't deselect them like vanilla Bug #5870: Disposing of actors who were selected in the console doesn't deselect them like vanilla
Bug #5883: Immobile creatures don't cause water ripples Bug #5883: Immobile creatures don't cause water ripples

View File

@ -82,7 +82,11 @@ namespace MWMechanics
void AiSequence::onPackageRemoved(const AiPackage& package) void AiSequence::onPackageRemoved(const AiPackage& package)
{ {
if (package.getTypeId() == AiPackageTypeId::Combat) if (package.getTypeId() == AiPackageTypeId::Combat)
{
mNumCombatPackages--; mNumCombatPackages--;
if (mNumCombatPackages == 0)
mResetFriendlyHits = true;
}
else if (package.getTypeId() == AiPackageTypeId::Pursue) else if (package.getTypeId() == AiPackageTypeId::Pursue)
mNumPursuitPackages--; mNumPursuitPackages--;
@ -246,6 +250,12 @@ namespace MWMechanics
return; return;
} }
if (mResetFriendlyHits)
{
actor.getClass().getCreatureStats(actor).resetFriendlyHits();
mResetFriendlyHits = false;
}
if (mPackages.empty()) if (mPackages.empty())
{ {
mLastAiPackage = AiPackageTypeId::None; mLastAiPackage = AiPackageTypeId::None;

View File

@ -39,6 +39,7 @@ namespace MWMechanics
/// Finished with top AIPackage, set for one frame /// Finished with top AIPackage, set for one frame
bool mDone{}; bool mDone{};
bool mResetFriendlyHits{};
int mNumCombatPackages{}; int mNumCombatPackages{};
int mNumPursuitPackages{}; int mNumPursuitPackages{};

View File

@ -674,6 +674,8 @@ namespace MWMechanics
return false; return false;
MWMechanics::CreatureStats& statsTarget = target.getClass().getCreatureStats(target); MWMechanics::CreatureStats& statsTarget = target.getClass().getCreatureStats(target);
if (statsTarget.getAiSequence().isInCombat())
return true;
statsTarget.friendlyHit(); statsTarget.friendlyHit();
if (statsTarget.getFriendlyHits() >= 4) if (statsTarget.getFriendlyHits() >= 4)
return false; return false;

View File

@ -319,6 +319,11 @@ namespace MWMechanics
++mFriendlyHits; ++mFriendlyHits;
} }
void CreatureStats::resetFriendlyHits()
{
mFriendlyHits = 0;
}
bool CreatureStats::hasTalkedToPlayer() const bool CreatureStats::hasTalkedToPlayer() const
{ {
return mTalkedTo; return mTalkedTo;

View File

@ -200,6 +200,8 @@ namespace MWMechanics
void friendlyHit(); void friendlyHit();
///< Increase number of friendly hits by one. ///< Increase number of friendly hits by one.
void resetFriendlyHits();
bool hasTalkedToPlayer() const; bool hasTalkedToPlayer() const;
///< Has this creature talked with the player before? ///< Has this creature talked with the player before?
@ -294,7 +296,7 @@ namespace MWMechanics
bool wasTeleported() const { return mTeleported; } bool wasTeleported() const { return mTeleported; }
void setTeleported(bool v) { mTeleported = v; } void setTeleported(bool v) { mTeleported = v; }
const std::map<ESM::RefId, AttributeValue> getAttributes() const { return mAttributes; } const std::map<ESM::RefId, AttributeValue>& getAttributes() const { return mAttributes; }
}; };
} }

View File

@ -1703,6 +1703,8 @@ namespace MWMechanics
// We don't care about dialogue filters since the target is invalid. // We don't care about dialogue filters since the target is invalid.
// We still want to play the combat taunt. // We still want to play the combat taunt.
MWBase::Environment::get().getDialogueManager()->say(ptr, ESM::RefId::stringRefId("attack")); MWBase::Environment::get().getDialogueManager()->say(ptr, ESM::RefId::stringRefId("attack"));
if (!stats.getAiSequence().isInCombat())
stats.resetFriendlyHits();
return; return;
} }