Use Delay Component (#540)
* use delay timer * remove accidental using * and remove accidental newline because i don't proofread my code * compatibility with HUD cooldown suggested changes * get out of here * suggested changes * change to seconds from milliseconds * remove redundancy
This commit is contained in:
@@ -0,0 +1,79 @@
|
|||||||
|
using System;
|
||||||
|
using CancellationTokenSource = System.Threading.CancellationTokenSource;
|
||||||
|
using Content.Shared.GameObjects.Components.Items;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.Serialization;
|
||||||
|
using Robust.Shared.Timers;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Interfaces.Timing;
|
||||||
|
|
||||||
|
namespace Content.Server.GameObjects.Components.Timing
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Timer that creates a cooldown each time an object is activated/used
|
||||||
|
/// </summary>
|
||||||
|
[RegisterComponent]
|
||||||
|
public class UseDelayComponent : Component
|
||||||
|
{
|
||||||
|
public override string Name => "UseDelay";
|
||||||
|
|
||||||
|
private TimeSpan _lastUseTime;
|
||||||
|
|
||||||
|
private float _delay;
|
||||||
|
/// <summary>
|
||||||
|
/// The time, in seconds, between an object's use and when it can be used again
|
||||||
|
/// </summary>
|
||||||
|
public float Delay { get => _delay; set => _delay = value; }
|
||||||
|
|
||||||
|
public bool ActiveDelay{ get; private set; }
|
||||||
|
|
||||||
|
private CancellationTokenSource cancellationTokenSource;
|
||||||
|
|
||||||
|
public override void ExposeData(ObjectSerializer serializer)
|
||||||
|
{
|
||||||
|
base.ExposeData(serializer);
|
||||||
|
serializer.DataField(ref _delay, "delay", 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void BeginDelay()
|
||||||
|
{
|
||||||
|
if (ActiveDelay)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
ActiveDelay = true;
|
||||||
|
|
||||||
|
cancellationTokenSource = new CancellationTokenSource();
|
||||||
|
|
||||||
|
Timer.Spawn(TimeSpan.FromSeconds(Delay), () => ActiveDelay = false, cancellationTokenSource.Token);
|
||||||
|
|
||||||
|
_lastUseTime = IoCManager.Resolve<IGameTiming>().CurTime;
|
||||||
|
|
||||||
|
if (Owner.TryGetComponent(out ItemCooldownComponent cooldown))
|
||||||
|
{
|
||||||
|
cooldown.CooldownStart = _lastUseTime;
|
||||||
|
cooldown.CooldownEnd = _lastUseTime + TimeSpan.FromSeconds(Delay);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Cancel()
|
||||||
|
{
|
||||||
|
cancellationTokenSource.Cancel();
|
||||||
|
ActiveDelay = false;
|
||||||
|
|
||||||
|
if (Owner.TryGetComponent(out ItemCooldownComponent cooldown))
|
||||||
|
{
|
||||||
|
cooldown.CooldownEnd = IoCManager.Resolve<IGameTiming>().CurTime;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Restart()
|
||||||
|
{
|
||||||
|
cancellationTokenSource.Cancel();
|
||||||
|
ActiveDelay = false;
|
||||||
|
BeginDelay();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Content.Server.GameObjects.Components.Mobs;
|
using Content.Server.GameObjects.Components.Mobs;
|
||||||
|
using Content.Server.GameObjects.Components.Timing;
|
||||||
using Content.Server.Interfaces.GameObjects;
|
using Content.Server.Interfaces.GameObjects;
|
||||||
using Content.Shared.Input;
|
using Content.Shared.Input;
|
||||||
using JetBrains.Annotations;
|
using JetBrains.Annotations;
|
||||||
@@ -560,6 +561,12 @@ namespace Content.Server.GameObjects.EntitySystems
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void UseInteraction(IEntity user, IEntity used)
|
public void UseInteraction(IEntity user, IEntity used)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if (used.TryGetComponent<UseDelayComponent>(out var delayComponent))
|
||||||
|
{
|
||||||
|
delayComponent.BeginDelay();
|
||||||
|
}
|
||||||
|
|
||||||
var useMsg = new UseInHandMessage(user, used);
|
var useMsg = new UseInHandMessage(user, used);
|
||||||
RaiseEvent(useMsg);
|
RaiseEvent(useMsg);
|
||||||
if (useMsg.Handled)
|
if (useMsg.Handled)
|
||||||
|
|||||||
@@ -15,7 +15,12 @@
|
|||||||
- type: Item
|
- type: Item
|
||||||
Size: 5
|
Size: 5
|
||||||
sprite: Objects/Fun/bikehorn.rsi
|
sprite: Objects/Fun/bikehorn.rsi
|
||||||
|
- type: ItemCooldown
|
||||||
|
|
||||||
- type: Sound
|
- type: Sound
|
||||||
- type: EmitSoundOnUse
|
- type: EmitSoundOnUse
|
||||||
sound: /Audio/items/bikehorn.ogg
|
sound: /Audio/items/bikehorn.ogg
|
||||||
|
|
||||||
|
- type: Timing
|
||||||
|
- type: UseDelay
|
||||||
|
delay: 0.5
|
||||||
|
|||||||
Reference in New Issue
Block a user