mirror of
https://github.com/WWhiteDreamProject/wwdpublic.git
synced 2026-04-18 05:59:03 +03:00
<!-- This is a semi-strict format, you can add/remove sections as needed but the order/format should be kept the same Remove these comments before submitting --> # Description the adding AI is now up to y'all because i'm not touching loadout code for name datasets, but it shouldn't be too bad from here --------- Signed-off-by: sleepyyapril <123355664+sleepyyapril@users.noreply.github.com> Signed-off-by: SolStar <44028047+ewokswagger@users.noreply.github.com> Signed-off-by: deltanedas <39013340+deltanedas@users.noreply.github.com> Co-authored-by: themias <89101928+themias@users.noreply.github.com> Co-authored-by: Verm <32827189+Vermidia@users.noreply.github.com> Co-authored-by: DrSmugleaf <10968691+DrSmugleaf@users.noreply.github.com> Co-authored-by: Sphiral <145869023+SphiraI@users.noreply.github.com> Co-authored-by: Ed <96445749+TheShuEd@users.noreply.github.com> Co-authored-by: Mr. 27 <45323883+Dutch-VanDerLinde@users.noreply.github.com> Co-authored-by: metalgearsloth <comedian_vs_clown@hotmail.com> Co-authored-by: Alzore <140123969+Blackern5000@users.noreply.github.com> Co-authored-by: ravage <142820619+ravage123321@users.noreply.github.com> Co-authored-by: slarticodefast <161409025+slarticodefast@users.noreply.github.com> Co-authored-by: Intoxicating-Innocence <188202277+Intoxicating-Innocence@users.noreply.github.com> Co-authored-by: Saphire <lattice@saphi.re> Co-authored-by: metalgearsloth <31366439+metalgearsloth@users.noreply.github.com> Co-authored-by: Errant <35878406+Errant-4@users.noreply.github.com> Co-authored-by: Tayrtahn <tayrtahn@gmail.com> Co-authored-by: CaasGit <87243814+CaasGit@users.noreply.github.com> Co-authored-by: BramvanZijp <56019239+BramvanZijp@users.noreply.github.com> Co-authored-by: Boaz1111 <149967078+Boaz1111@users.noreply.github.com> Co-authored-by: NakataRin <45946146+NakataRin@users.noreply.github.com> Co-authored-by: Kara <lunarautomaton6@gmail.com> Co-authored-by: Plykiya <58439124+Plykiya@users.noreply.github.com> Co-authored-by: SlamBamActionman <slambamactionman@gmail.com> Co-authored-by: Doomsdrayk <robotdoughnut@comcast.net> Co-authored-by: Brandon Hu <103440971+Brandon-Huu@users.noreply.github.com> Co-authored-by: SlamBamActionman <83650252+SlamBamActionman@users.noreply.github.com> Co-authored-by: ElectroJr <leonsfriedrich@gmail.com> Co-authored-by: Pieter-Jan Briers <pieterjan.briers+git@gmail.com> Co-authored-by: DrSmugleaf <DrSmugleaf@users.noreply.github.com> Co-authored-by: Julian Giebel <juliangiebel@live.de> Co-authored-by: nikthechampiongr <32041239+nikthechampiongr@users.noreply.github.com> Co-authored-by: Repo <47093363+Titian3@users.noreply.github.com> Co-authored-by: Chief-Engineer <119664036+Chief-Engineer@users.noreply.github.com> Co-authored-by: icekot8 <93311212+icekot8@users.noreply.github.com> Co-authored-by: AJCM-git <60196617+AJCM-git@users.noreply.github.com> Co-authored-by: Leon Friedrich <60421075+ElectroJr@users.noreply.github.com> Co-authored-by: no <165581243+pissdemon@users.noreply.github.com> Co-authored-by: Tornado Tech <54727692+Tornado-Technology@users.noreply.github.com> Co-authored-by: osjarw <62134478+osjarw@users.noreply.github.com> Co-authored-by: Simon <63975668+Simyon264@users.noreply.github.com> Co-authored-by: TGRCDev <tgrc@tgrc.dev> Co-authored-by: Milon <milonpl.git@proton.me> Co-authored-by: deltanedas <39013340+deltanedas@users.noreply.github.com> Co-authored-by: ShadowCommander <10494922+ShadowCommander@users.noreply.github.com> Co-authored-by: Fildrance <fildrance@gmail.com> Co-authored-by: pa.pecherskij <pa.pecherskij@interfax.ru> Co-authored-by: chavonadelal <156101927+chavonadelal@users.noreply.github.com> Co-authored-by: SolStar <44028047+ewokswagger@users.noreply.github.com> Co-authored-by: K-Dynamic <20566341+K-Dynamic@users.noreply.github.com> Co-authored-by: lzk <124214523+lzk228@users.noreply.github.com> Co-authored-by: ArchRBX <5040911+ArchRBX@users.noreply.github.com> Co-authored-by: archrbx <punk.gear5260@fastmail.com> Co-authored-by: Radezolid <snappednexus@gmail.com> Co-authored-by: Nemanja <98561806+EmoGarbage404@users.noreply.github.com> Co-authored-by: EmoGarbage404 <retron404@gmail.com> Co-authored-by: MilenVolf <63782763+MilenVolf@users.noreply.github.com> Co-authored-by: Velcroboy <107660393+IamVelcroboy@users.noreply.github.com> Co-authored-by: Velcroboy <velcroboy333@hotmail.com> Co-authored-by: neuPanda <chriseparton@gmail.com> Co-authored-by: neuPanda <spainman0@yahoo.com> Co-authored-by: Dvir <39403717+dvir001@users.noreply.github.com> Co-authored-by: Whatstone <whatston3@gmail.com> Co-authored-by: VideoKompany <135313844+VlaDOS1408@users.noreply.github.com> (cherry picked from commit 93ed70acfeda357133a701f637d3faeec02749bb)
251 lines
8.6 KiB
C#
251 lines
8.6 KiB
C#
using Content.Shared.Hands.EntitySystems;
|
|
using Content.Shared.Interaction;
|
|
using Content.Shared.Verbs;
|
|
using Content.Shared.Examine;
|
|
using Content.Shared.Item.ItemToggle.Components;
|
|
using Content.Shared.Storage;
|
|
using JetBrains.Annotations;
|
|
using Robust.Shared.Containers;
|
|
using Robust.Shared.GameStates;
|
|
using Robust.Shared.Prototypes;
|
|
using Robust.Shared.Utility;
|
|
|
|
namespace Content.Shared.Item;
|
|
|
|
public abstract class SharedItemSystem : EntitySystem
|
|
{
|
|
[Dependency] private readonly IPrototypeManager _prototype = default!;
|
|
[Dependency] private readonly SharedHandsSystem _handsSystem = default!;
|
|
[Dependency] protected readonly SharedContainerSystem Container = default!;
|
|
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
SubscribeLocalEvent<ItemComponent, GetVerbsEvent<InteractionVerb>>(AddPickupVerb);
|
|
SubscribeLocalEvent<ItemComponent, InteractHandEvent>(OnHandInteract);
|
|
SubscribeLocalEvent<ItemComponent, AfterAutoHandleStateEvent>(OnItemAutoState);
|
|
|
|
SubscribeLocalEvent<ItemComponent, ExaminedEvent>(OnExamine);
|
|
|
|
SubscribeLocalEvent<ItemToggleSizeComponent, ItemToggledEvent>(OnItemToggle);
|
|
}
|
|
|
|
private void OnItemAutoState(EntityUid uid, ItemComponent component, ref AfterAutoHandleStateEvent args)
|
|
{
|
|
SetHeldPrefix(uid, component.HeldPrefix, force: true, component);
|
|
}
|
|
|
|
#region Public API
|
|
|
|
public void SetSize(EntityUid uid, ProtoId<ItemSizePrototype> size, ItemComponent? component = null)
|
|
{
|
|
if (!Resolve(uid, ref component, false))
|
|
return;
|
|
|
|
component.Size = size;
|
|
Dirty(uid, component);
|
|
}
|
|
|
|
public void SetShape(EntityUid uid, List<Box2i>? shape, ItemComponent? component = null)
|
|
{
|
|
if (!Resolve(uid, ref component, false))
|
|
return;
|
|
|
|
component.Shape = shape;
|
|
Dirty(uid, component);
|
|
}
|
|
|
|
public void SetHeldPrefix(EntityUid uid, string? heldPrefix, bool force = false, ItemComponent? component = null)
|
|
{
|
|
if (!Resolve(uid, ref component, false))
|
|
return;
|
|
|
|
if (!force && component.HeldPrefix == heldPrefix)
|
|
return;
|
|
|
|
component.HeldPrefix = heldPrefix;
|
|
Dirty(uid, component);
|
|
VisualsChanged(uid);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Copy all item specific visuals from another item.
|
|
/// </summary>
|
|
public void CopyVisuals(EntityUid uid, ItemComponent otherItem, ItemComponent? item = null)
|
|
{
|
|
if (!Resolve(uid, ref item))
|
|
return;
|
|
|
|
item.RsiPath = otherItem.RsiPath;
|
|
item.InhandVisuals = otherItem.InhandVisuals;
|
|
item.HeldPrefix = otherItem.HeldPrefix;
|
|
|
|
Dirty(uid, item);
|
|
VisualsChanged(uid);
|
|
}
|
|
|
|
#endregion
|
|
|
|
private void OnHandInteract(EntityUid uid, ItemComponent component, InteractHandEvent args)
|
|
{
|
|
if (args.Handled)
|
|
return;
|
|
|
|
args.Handled = _handsSystem.TryPickup(args.User, uid, animateUser: false);
|
|
}
|
|
|
|
private void AddPickupVerb(EntityUid uid, ItemComponent component, GetVerbsEvent<InteractionVerb> args)
|
|
{
|
|
if (args.Hands == null ||
|
|
args.Using != null ||
|
|
!args.CanAccess ||
|
|
!args.CanInteract ||
|
|
!_handsSystem.CanPickupAnyHand(args.User, args.Target, handsComp: args.Hands, item: component))
|
|
return;
|
|
|
|
InteractionVerb verb = new();
|
|
verb.Act = () => _handsSystem.TryPickupAnyHand(args.User, args.Target, checkActionBlocker: false,
|
|
handsComp: args.Hands, item: component);
|
|
verb.Icon = new SpriteSpecifier.Texture(new("/Textures/Interface/VerbIcons/pickup.svg.192dpi.png"));
|
|
|
|
// if the item already in a container (that is not the same as the user's), then change the text.
|
|
// this occurs when the item is in their inventory or in an open backpack
|
|
Container.TryGetContainingContainer((args.User, null, null), out var userContainer);
|
|
if (Container.TryGetContainingContainer((args.Target, null, null), out var container) && container != userContainer)
|
|
verb.Text = Loc.GetString("pick-up-verb-get-data-text-inventory");
|
|
else
|
|
verb.Text = Loc.GetString("pick-up-verb-get-data-text");
|
|
|
|
args.Verbs.Add(verb);
|
|
}
|
|
|
|
private void OnExamine(EntityUid uid, ItemComponent component, ExaminedEvent args)
|
|
{
|
|
// show at end of message generally
|
|
args.PushMarkup(Loc.GetString("item-component-on-examine-size",
|
|
("size", GetItemSizeLocale(component.Size))), priority: -1);
|
|
}
|
|
|
|
public ItemSizePrototype GetSizePrototype(ProtoId<ItemSizePrototype> id)
|
|
{
|
|
return _prototype.Index(id);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Notifies any entity that is holding or wearing this item that they may need to update their sprite.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// This is used for updating both inhand sprites and clothing sprites, but it's here just cause it needs to
|
|
/// be in one place.
|
|
/// </remarks>
|
|
public virtual void VisualsChanged(EntityUid owner)
|
|
{
|
|
}
|
|
|
|
[PublicAPI]
|
|
public string GetItemSizeLocale(ProtoId<ItemSizePrototype> size)
|
|
{
|
|
return Loc.GetString(GetSizePrototype(size).Name);
|
|
}
|
|
|
|
[PublicAPI]
|
|
public int GetItemSizeWeight(ProtoId<ItemSizePrototype> size)
|
|
{
|
|
return GetSizePrototype(size).Weight;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the default shape of an item.
|
|
/// </summary>
|
|
public IReadOnlyList<Box2i> GetItemShape(Entity<ItemComponent?> uid)
|
|
{
|
|
if (!Resolve(uid, ref uid.Comp))
|
|
return new Box2i[] { };
|
|
|
|
return uid.Comp.Shape ?? GetSizePrototype(uid.Comp.Size).DefaultShape;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the default shape of an item.
|
|
/// </summary>
|
|
public IReadOnlyList<Box2i> GetItemShape(ItemComponent component)
|
|
{
|
|
return component.Shape ?? GetSizePrototype(component.Size).DefaultShape;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the shape of an item, adjusting for rotation and offset.
|
|
/// </summary>
|
|
public IReadOnlyList<Box2i> GetAdjustedItemShape(Entity<ItemComponent?> entity, ItemStorageLocation location)
|
|
{
|
|
return GetAdjustedItemShape(entity, location.Rotation, location.Position);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the shape of an item, adjusting for rotation and offset.
|
|
/// </summary>
|
|
public IReadOnlyList<Box2i> GetAdjustedItemShape(Entity<ItemComponent?> entity, Angle rotation, Vector2i position)
|
|
{
|
|
if (!Resolve(entity, ref entity.Comp))
|
|
return new Box2i[] { };
|
|
|
|
var shapes = GetItemShape(entity);
|
|
var boundingShape = shapes.GetBoundingBox();
|
|
var boundingCenter = ((Box2) boundingShape).Center;
|
|
var matty = Matrix3Helpers.CreateTransform(boundingCenter, rotation);
|
|
var drift = boundingShape.BottomLeft - matty.TransformBox(boundingShape).BottomLeft;
|
|
|
|
var adjustedShapes = new List<Box2i>();
|
|
foreach (var shape in shapes)
|
|
{
|
|
var transformed = matty.TransformBox(shape).Translated(drift);
|
|
var floored = new Box2i(transformed.BottomLeft.Floored(), transformed.TopRight.Floored());
|
|
var translated = floored.Translated(position);
|
|
|
|
adjustedShapes.Add(translated);
|
|
}
|
|
|
|
return adjustedShapes;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Used to update the Item component on item toggle (specifically size).
|
|
/// </summary>
|
|
private void OnItemToggle(EntityUid uid, ItemToggleSizeComponent itemToggleSize, ItemToggledEvent args)
|
|
{
|
|
if (!TryComp(uid, out ItemComponent? item))
|
|
return;
|
|
|
|
if (args.Activated)
|
|
{
|
|
if (itemToggleSize.ActivatedShape != null)
|
|
{
|
|
// Set the deactivated shape to the default item's shape before it gets changed.
|
|
itemToggleSize.DeactivatedShape ??= new List<Box2i>(GetItemShape(item));
|
|
SetShape(uid, itemToggleSize.ActivatedShape, item);
|
|
}
|
|
|
|
if (itemToggleSize.ActivatedSize != null)
|
|
{
|
|
// Set the deactivated size to the default item's size before it gets changed.
|
|
itemToggleSize.DeactivatedSize ??= item.Size;
|
|
SetSize(uid, (ProtoId<ItemSizePrototype>) itemToggleSize.ActivatedSize, item);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (itemToggleSize.DeactivatedShape != null)
|
|
{
|
|
SetShape(uid, itemToggleSize.DeactivatedShape, item);
|
|
}
|
|
|
|
if (itemToggleSize.DeactivatedSize != null)
|
|
{
|
|
SetSize(uid, (ProtoId<ItemSizePrototype>) itemToggleSize.DeactivatedSize, item);
|
|
}
|
|
}
|
|
|
|
Dirty(uid, item);
|
|
}
|
|
}
|