From 33a0886790f3b2b95707f6ed863451f1afa4d2a5 Mon Sep 17 00:00:00 2001 From: David Cernat Date: Sat, 15 Sep 2018 04:59:06 +0300 Subject: [PATCH] [Client] Fix synchronization of knockdown states --- apps/openmw/mwclass/creature.cpp | 27 +++++++++++++++++++-------- apps/openmw/mwclass/npc.cpp | 27 +++++++++++++++++++-------- 2 files changed, 38 insertions(+), 16 deletions(-) diff --git a/apps/openmw/mwclass/creature.cpp b/apps/openmw/mwclass/creature.cpp index db844bf17..37916b69c 100644 --- a/apps/openmw/mwclass/creature.cpp +++ b/apps/openmw/mwclass/creature.cpp @@ -498,20 +498,31 @@ namespace MWClass /* Start of tes3mp change (major) - If the attacker is a DedicatedPlayer or DedicatedActor with a successful knockdown, apply the knockdown; - otherwise, use default probability roll + If the attacker is a DedicatedPlayer or DedicatedActor with a successful knockdown, apply the knockdown + + If the attacker is neither of those, then it must be a LocalPlayer or a LocalActor, so calculate the + knockdown probability on our client + + Default to hit recovery if no knockdown has taken place, like in regular OpenMW */ mwmp::Attack *dedicatedAttack = MechanicsHelper::getDedicatedAttack(attacker); - if (dedicatedAttack && dedicatedAttack->knockdown) - stats.setKnockedDown(true); - else if (ishealth && agilityTerm <= damage && knockdownTerm <= Misc::Rng::roll0to99()) + if (dedicatedAttack) + { + if (dedicatedAttack->knockdown) + stats.setKnockedDown(true); + } + else + { + if (ishealth && agilityTerm <= damage && knockdownTerm <= Misc::Rng::roll0to99()) + stats.setKnockedDown(true); + } + + if (!stats.getKnockedDown()) + stats.setHitRecovery(true); // Is this supposed to always occur? /* End of tes3mp change (major) */ - stats.setKnockedDown(true); - else - stats.setHitRecovery(true); // Is this supposed to always occur? } damage = std::max(1.f, damage); diff --git a/apps/openmw/mwclass/npc.cpp b/apps/openmw/mwclass/npc.cpp index 505ce7878..9409d5e53 100644 --- a/apps/openmw/mwclass/npc.cpp +++ b/apps/openmw/mwclass/npc.cpp @@ -837,20 +837,31 @@ namespace MWClass /* Start of tes3mp change (major) - If the attacker is a DedicatedPlayer or DedicatedActor with a successful knockdown, apply the knockdown; - otherwise, use default probability roll + If the attacker is a DedicatedPlayer or DedicatedActor with a successful knockdown, apply the knockdown + + If the attacker is neither of those, then it must be a LocalPlayer or a LocalActor, so calculate the + knockdown probability on our client + + Default to hit recovery if no knockdown has taken place, like in regular OpenMW */ mwmp::Attack *dedicatedAttack = MechanicsHelper::getDedicatedAttack(attacker); - if (dedicatedAttack && dedicatedAttack->knockdown) - stats.setKnockedDown(true); - else if (ishealth && agilityTerm <= damage && knockdownTerm <= Misc::Rng::roll0to99()) + if (dedicatedAttack) + { + if (dedicatedAttack->knockdown) + stats.setKnockedDown(true); + } + else + { + if (ishealth && agilityTerm <= damage && knockdownTerm <= Misc::Rng::roll0to99()) + stats.setKnockedDown(true); + } + + if (!stats.getKnockedDown()) + stats.setHitRecovery(true); // Is this supposed to always occur? /* End of tes3mp change (major) */ - stats.setKnockedDown(true); - else - stats.setHitRecovery(true); // Is this supposed to always occur? if (damage > 0 && ishealth) {