Storage system refactor & map init.
* Demonstrated map init working with guns, toolboxes, tool lockers. * Refactored EntityStorage and ServerStorage to have a common interface. * EntityStorage no longer uses ServerStorage PURELY for visuals. Use an appearance visualizer instead.
This commit is contained in:
@@ -26,19 +26,6 @@ namespace Content.Client.GameObjects.Components.Storage
|
||||
private int StorageCapacityMax;
|
||||
private StorageWindow Window;
|
||||
|
||||
[ViewVariables] private string _closedState;
|
||||
[ViewVariables] private string _openState;
|
||||
|
||||
public bool Open
|
||||
{
|
||||
get => _open;
|
||||
set
|
||||
{
|
||||
_open = value;
|
||||
SetDoorSprite(_open);
|
||||
}
|
||||
}
|
||||
|
||||
public override void OnAdd()
|
||||
{
|
||||
base.OnAdd();
|
||||
@@ -56,20 +43,6 @@ namespace Content.Client.GameObjects.Components.Storage
|
||||
public override void ExposeData(ObjectSerializer serializer)
|
||||
{
|
||||
base.ExposeData(serializer);
|
||||
|
||||
serializer.DataField(ref _closedState, "state_door_closed", null);
|
||||
serializer.DataField(ref _openState, "state_door_open", null);
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public override void HandleComponentState(ComponentState curState, ComponentState nextState)
|
||||
{
|
||||
base.HandleComponentState(curState, nextState);
|
||||
|
||||
if (!(curState is StorageComponentState storageState))
|
||||
return;
|
||||
|
||||
Open = storageState.Open;
|
||||
}
|
||||
|
||||
public override void HandleMessage(ComponentMessage message, INetChannel netChannel = null, IComponent component = null)
|
||||
@@ -125,27 +98,6 @@ namespace Content.Client.GameObjects.Components.Storage
|
||||
SendNetworkMessage(new RemoveEntityMessage(entityuid));
|
||||
}
|
||||
|
||||
private void SetDoorSprite(bool open)
|
||||
{
|
||||
if(!Owner.TryGetComponent<ISpriteComponent>(out var spriteComp))
|
||||
return;
|
||||
|
||||
if(!spriteComp.Running)
|
||||
return;
|
||||
|
||||
if (spriteComp.BaseRSI == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
var baseName = spriteComp.LayerGetState(0).Name;
|
||||
|
||||
var stateId = open ? _openState ?? $"{baseName}_open" : _closedState ?? $"{baseName}_door";
|
||||
|
||||
if (spriteComp.BaseRSI.TryGetState(stateId, out _))
|
||||
spriteComp.LayerSetState(1, stateId);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// GUI class for client storage component
|
||||
/// </summary>
|
||||
|
||||
@@ -0,0 +1,47 @@
|
||||
using Content.Shared.GameObjects.Components.Storage;
|
||||
using Robust.Client.GameObjects;
|
||||
using Robust.Client.Interfaces.GameObjects.Components;
|
||||
using Robust.Shared.Utility;
|
||||
using YamlDotNet.RepresentationModel;
|
||||
|
||||
namespace Content.Client.GameObjects.Components.Storage
|
||||
{
|
||||
public sealed class StorageVisualizer2D : AppearanceVisualizer
|
||||
{
|
||||
private string _stateOpen;
|
||||
private string _stateClosed;
|
||||
|
||||
public override void LoadData(YamlMappingNode node)
|
||||
{
|
||||
base.LoadData(node);
|
||||
|
||||
if (node.TryGetNode("state_open", out var child))
|
||||
{
|
||||
_stateOpen = child.AsString();
|
||||
}
|
||||
|
||||
if (node.TryGetNode("state_closed", out child))
|
||||
{
|
||||
_stateClosed = child.AsString();
|
||||
}
|
||||
}
|
||||
|
||||
public override void OnChangeData(AppearanceComponent component)
|
||||
{
|
||||
base.OnChangeData(component);
|
||||
|
||||
if (!component.Owner.TryGetComponent(out ISpriteComponent sprite))
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
component.TryGetData(StorageVisuals.Open, out bool open);
|
||||
sprite.LayerSetState(StorageVisualLayers.Door, open ? _stateOpen : _stateClosed);
|
||||
}
|
||||
}
|
||||
|
||||
public enum StorageVisualLayers
|
||||
{
|
||||
Door
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user