Files
crystall-punk-14/Content.Shared/Item/ItemComponent.cs

81 lines
2.7 KiB
C#
Raw Permalink Normal View History

using Content.Shared.Hands.Components;
using Robust.Shared.GameStates;
using Robust.Shared.Prototypes;
2022-07-27 03:53:47 -07:00
using Robust.Shared.Serialization;
2023-12-06 19:59:16 -05:00
using Robust.Shared.Utility;
2022-07-27 03:53:47 -07:00
namespace Content.Shared.Item;
/// <summary>
/// Handles items which can be picked up to hands and placed in pockets, as well as storage containers
/// like backpacks.
/// </summary>
[RegisterComponent]
[NetworkedComponent]
[Access(typeof(SharedItemSystem)), AutoGenerateComponentState(true)]
public sealed partial class ItemComponent : Component
2022-07-27 03:53:47 -07:00
{
[DataField, ViewVariables(VVAccess.ReadWrite), AutoNetworkedField]
[Access(typeof(SharedItemSystem))]
public ProtoId<ItemSizePrototype> Size = "Small";
2022-07-27 03:53:47 -07:00
[Access(typeof(SharedItemSystem))]
[DataField]
public Dictionary<HandLocation, List<PrototypeLayerData>> InhandVisuals = new();
2022-07-27 03:53:47 -07:00
[Access(typeof(SharedItemSystem))]
[ViewVariables(VVAccess.ReadWrite)]
[DataField, AutoNetworkedField]
2022-07-27 03:53:47 -07:00
public string? HeldPrefix;
/// <summary>
/// Rsi of the sprite shown on the player when this item is in their hands. Used to generate a default entry for <see cref="InhandVisuals"/>
/// </summary>
[Access(typeof(SharedItemSystem))]
2022-07-27 03:53:47 -07:00
[ViewVariables(VVAccess.ReadWrite)]
[DataField("sprite")]
public string? RsiPath;
/// <summary>
/// An optional override for the shape of the item within the grid storage.
/// If null, a default shape will be used based on <see cref="Size"/>.
/// </summary>
[DataField, AutoNetworkedField]
public List<Box2i>? Shape;
2023-12-06 19:59:16 -05:00
/// <summary>
/// A sprite used to depict this entity specifically when it is displayed in the storage UI.
/// </summary>
[DataField, AutoNetworkedField]
public SpriteSpecifier? StoredSprite;
/// <summary>
/// An additional angle offset, in degrees, applied to the visual depiction of the item when displayed in the storage UI.
/// </summary>
[DataField, AutoNetworkedField]
public float StoredRotation = 0;
2024-01-14 17:44:17 +01:00
/// <summary>
/// An additional offset, in pixels, applied to the visual depiction of the item when displayed in the storage UI.
/// </summary>
[DataField, AutoNetworkedField]
public Vector2i StoredOffset;
2022-07-27 03:53:47 -07:00
}
/// <summary>
/// Raised when an item's visual state is changed. The event is directed at the entity that contains this item, so
/// that it can properly update its hands or inventory sprites and GUI.
/// </summary>
[Serializable, NetSerializable]
public sealed class VisualsChangedEvent : EntityEventArgs
{
public readonly NetEntity Item;
2022-07-27 03:53:47 -07:00
public readonly string ContainerId;
public VisualsChangedEvent(NetEntity item, string containerId)
2022-07-27 03:53:47 -07:00
{
Item = item;
ContainerId = containerId;
}
}