]> git.smokeofanarchy.ru Git - space-station-14.git/commitdiff
Fix riot shield audio and popup spam (#21881)
authorthemias <89101928+themias@users.noreply.github.com>
Tue, 28 Nov 2023 07:06:38 +0000 (02:06 -0500)
committerGitHub <noreply@github.com>
Tue, 28 Nov 2023 07:06:38 +0000 (00:06 -0700)
Content.Shared/Blocking/BlockingSystem.User.cs
Content.Shared/Blocking/BlockingSystem.cs

index 2d721390e67c0f16d36bba0c3fcdd1aa42bf144b..87f285597f80eec4f8c07b71e3c55ca29f4b4a6c 100644 (file)
@@ -1,4 +1,4 @@
-using Content.Shared.Damage;
+using Content.Shared.Damage;
 using Content.Shared.Damage.Prototypes;
 using Robust.Shared.Audio;
 using Robust.Shared.Audio.Systems;
@@ -44,6 +44,9 @@ public sealed partial class BlockingSystem
     {
         if (TryComp<BlockingComponent>(component.BlockingItem, out var blocking))
         {
+            if (args.Damage.GetTotal() <= 0)
+                return;
+
             var blockFraction = blocking.IsBlocking ? blocking.ActiveBlockFraction : blocking.PassiveBlockFraction;
             blockFraction = Math.Clamp(blockFraction, 0, 1);
             _damageable.TryChangeDamage(component.BlockingItem, blockFraction * args.OriginalDamage);
index f46b202aaae7e1d5cbd51ca922b5311a4f78bae3..d616d55eb92187dd0fcb55f22bf3cbe4786beae5 100644 (file)
@@ -19,6 +19,7 @@ using Robust.Shared.Physics.Components;
 using Robust.Shared.Physics.Systems;
 using Robust.Shared.Player;
 using Robust.Shared.Prototypes;
+using Robust.Shared.Timing;
 using Robust.Shared.Utility;
 
 namespace Content.Shared.Blocking;
@@ -36,6 +37,7 @@ public sealed partial class BlockingSystem : EntitySystem
     [Dependency] private readonly SharedPhysicsSystem _physics = default!;
     [Dependency] private readonly ExamineSystemShared _examine = default!;
     [Dependency] private readonly INetManager _net = default!;
+    [Dependency] private readonly IGameTiming _gameTiming = default!;
 
     public override void Initialize()
     {
@@ -195,8 +197,12 @@ public sealed partial class BlockingSystem : EntitySystem
                 return false;
             }
             _actionsSystem.SetToggled(component.BlockingToggleActionEntity, true);
-            _popupSystem.PopupEntity(msgUser, user, user);
-            _popupSystem.PopupEntity(msgOther, user, Filter.PvsExcept(user), true);
+            if (_gameTiming.IsFirstTimePredicted)
+            {
+                _popupSystem.PopupEntity(msgOther, user, Filter.PvsExcept(user), true);
+                if(_gameTiming.InPrediction)
+                    _popupSystem.PopupEntity(msgUser, user, user);
+            }
         }
 
         if (TryComp<PhysicsComponent>(user, out var physicsComponent))
@@ -259,8 +265,12 @@ public sealed partial class BlockingSystem : EntitySystem
             _actionsSystem.SetToggled(component.BlockingToggleActionEntity, false);
             _fixtureSystem.DestroyFixture(user, BlockingComponent.BlockFixtureID, body: physicsComponent);
             _physics.SetBodyType(user, blockingUserComponent.OriginalBodyType, body: physicsComponent);
-            _popupSystem.PopupEntity(msgUser, user, user);
-            _popupSystem.PopupEntity(msgOther, user, Filter.PvsExcept(user), true);
+            if (_gameTiming.IsFirstTimePredicted)
+            {
+                _popupSystem.PopupEntity(msgOther, user, Filter.PvsExcept(user), true);
+                if(_gameTiming.InPrediction)
+                    _popupSystem.PopupEntity(msgUser, user, user);
+            }
         }
 
         component.IsBlocking = false;