Predicted multihanded component (#36712)
* Predicted multihanded component * Refview * reh
This commit is contained in:
@@ -1,15 +0,0 @@
|
|||||||
using Content.Shared.Hands;
|
|
||||||
using Content.Shared.Item;
|
|
||||||
|
|
||||||
namespace Content.Client.Items.Systems;
|
|
||||||
|
|
||||||
public sealed class MultiHandedItemSystem : SharedMultiHandedItemSystem
|
|
||||||
{
|
|
||||||
protected override void OnEquipped(EntityUid uid, MultiHandedItemComponent component, GotEquippedHandEvent args)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnUnequipped(EntityUid uid, MultiHandedItemComponent component, GotUnequippedHandEvent args)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
using Content.Server.Hands.Systems;
|
|
||||||
using Content.Server.Inventory;
|
|
||||||
using Content.Shared.Hands;
|
|
||||||
using Content.Shared.Item;
|
|
||||||
|
|
||||||
namespace Content.Server.Item;
|
|
||||||
|
|
||||||
public sealed class MultiHandedItemSystem : SharedMultiHandedItemSystem
|
|
||||||
{
|
|
||||||
[Dependency] private readonly VirtualItemSystem _virtualItem = default!;
|
|
||||||
|
|
||||||
protected override void OnEquipped(EntityUid uid, MultiHandedItemComponent component, GotEquippedHandEvent args)
|
|
||||||
{
|
|
||||||
for (var i = 0; i < component.HandsNeeded - 1; i++)
|
|
||||||
{
|
|
||||||
_virtualItem.TrySpawnVirtualItemInHand(uid, args.User);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnUnequipped(EntityUid uid, MultiHandedItemComponent component, GotUnequippedHandEvent args)
|
|
||||||
{
|
|
||||||
_virtualItem.DeleteInHandsMatching(args.User, uid);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -9,6 +9,6 @@ namespace Content.Shared.Item;
|
|||||||
[RegisterComponent, NetworkedComponent]
|
[RegisterComponent, NetworkedComponent]
|
||||||
public sealed partial class MultiHandedItemComponent : Component
|
public sealed partial class MultiHandedItemComponent : Component
|
||||||
{
|
{
|
||||||
[DataField("handsNeeded"), ViewVariables(VVAccess.ReadWrite)]
|
[DataField]
|
||||||
public int HandsNeeded = 2;
|
public int HandsNeeded = 2;
|
||||||
}
|
}
|
||||||
|
|||||||
56
Content.Shared/Item/MultiHandedItemSystem.cs
Normal file
56
Content.Shared/Item/MultiHandedItemSystem.cs
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
using Content.Shared.Hands;
|
||||||
|
using Content.Shared.Hands.Components;
|
||||||
|
using Content.Shared.Hands.EntitySystems;
|
||||||
|
using Content.Shared.Inventory.VirtualItem;
|
||||||
|
using Content.Shared.Popups;
|
||||||
|
using Robust.Shared.Timing;
|
||||||
|
|
||||||
|
namespace Content.Shared.Item;
|
||||||
|
|
||||||
|
public sealed class MultiHandedItemSystem : EntitySystem
|
||||||
|
{
|
||||||
|
[Dependency] private readonly IGameTiming _timing = default!;
|
||||||
|
[Dependency] private readonly SharedHandsSystem _hands = default!;
|
||||||
|
[Dependency] private readonly SharedPopupSystem _popup = default!;
|
||||||
|
[Dependency] private readonly SharedVirtualItemSystem _virtualItem = default!;
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override void Initialize()
|
||||||
|
{
|
||||||
|
SubscribeLocalEvent<MultiHandedItemComponent, GettingPickedUpAttemptEvent>(OnAttemptPickup);
|
||||||
|
SubscribeLocalEvent<MultiHandedItemComponent, VirtualItemDeletedEvent>(OnVirtualItemDeleted);
|
||||||
|
SubscribeLocalEvent<MultiHandedItemComponent, GotEquippedHandEvent>(OnEquipped);
|
||||||
|
SubscribeLocalEvent<MultiHandedItemComponent, GotUnequippedHandEvent>(OnUnequipped);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnEquipped(Entity<MultiHandedItemComponent> ent, ref GotEquippedHandEvent args)
|
||||||
|
{
|
||||||
|
for (var i = 0; i < ent.Comp.HandsNeeded - 1; i++)
|
||||||
|
{
|
||||||
|
_virtualItem.TrySpawnVirtualItemInHand(ent.Owner, args.User);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnUnequipped(Entity<MultiHandedItemComponent> ent, ref GotUnequippedHandEvent args)
|
||||||
|
{
|
||||||
|
_virtualItem.DeleteInHandsMatching(args.User, ent.Owner);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnAttemptPickup(Entity<MultiHandedItemComponent> ent, ref GettingPickedUpAttemptEvent args)
|
||||||
|
{
|
||||||
|
if (TryComp<HandsComponent>(args.User, out var hands) && hands.CountFreeHands() >= ent.Comp.HandsNeeded)
|
||||||
|
return;
|
||||||
|
|
||||||
|
args.Cancel();
|
||||||
|
_popup.PopupPredictedCursor(Loc.GetString("multi-handed-item-pick-up-fail",
|
||||||
|
("number", ent.Comp.HandsNeeded - 1), ("item", ent.Owner)), args.User);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnVirtualItemDeleted(Entity<MultiHandedItemComponent> ent, ref VirtualItemDeletedEvent args)
|
||||||
|
{
|
||||||
|
if (args.BlockingEntity != ent.Owner || _timing.ApplyingState)
|
||||||
|
return;
|
||||||
|
|
||||||
|
_hands.TryDrop(args.User, ent.Owner);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
using Content.Shared.Hands;
|
|
||||||
using Content.Shared.Hands.Components;
|
|
||||||
using Content.Shared.Hands.EntitySystems;
|
|
||||||
using Content.Shared.Popups;
|
|
||||||
using Robust.Shared.Timing;
|
|
||||||
|
|
||||||
namespace Content.Shared.Item;
|
|
||||||
|
|
||||||
public abstract class SharedMultiHandedItemSystem : EntitySystem
|
|
||||||
{
|
|
||||||
[Dependency] private readonly IGameTiming _timing = default!;
|
|
||||||
[Dependency] private readonly SharedHandsSystem _hands = default!;
|
|
||||||
[Dependency] private readonly SharedPopupSystem _popup = default!;
|
|
||||||
|
|
||||||
/// <inheritdoc/>
|
|
||||||
public override void Initialize()
|
|
||||||
{
|
|
||||||
SubscribeLocalEvent<MultiHandedItemComponent, GettingPickedUpAttemptEvent>(OnAttemptPickup);
|
|
||||||
SubscribeLocalEvent<MultiHandedItemComponent, VirtualItemDeletedEvent>(OnVirtualItemDeleted);
|
|
||||||
SubscribeLocalEvent<MultiHandedItemComponent, GotEquippedHandEvent>(OnEquipped);
|
|
||||||
SubscribeLocalEvent<MultiHandedItemComponent, GotUnequippedHandEvent>(OnUnequipped);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract void OnEquipped(EntityUid uid, MultiHandedItemComponent component, GotEquippedHandEvent args);
|
|
||||||
protected abstract void OnUnequipped(EntityUid uid, MultiHandedItemComponent component, GotUnequippedHandEvent args);
|
|
||||||
|
|
||||||
private void OnAttemptPickup(EntityUid uid, MultiHandedItemComponent component, GettingPickedUpAttemptEvent args)
|
|
||||||
{
|
|
||||||
if (TryComp<HandsComponent>(args.User, out var hands) && hands.CountFreeHands() >= component.HandsNeeded)
|
|
||||||
return;
|
|
||||||
|
|
||||||
args.Cancel();
|
|
||||||
if (_timing.IsFirstTimePredicted)
|
|
||||||
{
|
|
||||||
_popup.PopupCursor(Loc.GetString("multi-handed-item-pick-up-fail",
|
|
||||||
("number", component.HandsNeeded - 1), ("item", uid)), args.User);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void OnVirtualItemDeleted(EntityUid uid, MultiHandedItemComponent component, VirtualItemDeletedEvent args)
|
|
||||||
{
|
|
||||||
if (args.BlockingEntity != uid)
|
|
||||||
return;
|
|
||||||
|
|
||||||
_hands.TryDrop(args.User, uid);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user