GasFilter appearance, EnabledAtmosDeviceVisualizer improvements.

This commit is contained in:
Vera Aguilera Puerto
2021-08-02 13:20:31 +02:00
parent 5422724040
commit 331604cc66
15 changed files with 68 additions and 41 deletions

View File

@@ -9,22 +9,13 @@ namespace Content.Client.Atmos.Visualizers
[UsedImplicitly] [UsedImplicitly]
public abstract class EnabledAtmosDeviceVisualizer : AppearanceVisualizer public abstract class EnabledAtmosDeviceVisualizer : AppearanceVisualizer
{ {
[DataField("disabledState")]
private string _disabledState = string.Empty;
[DataField("enabledState")] [DataField("enabledState")]
private string _enabledState = string.Empty; private string _enabledState = string.Empty;
protected abstract object LayerMap { get; } protected abstract object LayerMap { get; }
protected abstract Enum DataKey { get; } protected abstract Enum DataKey { get; }
public override void InitializeEntity(IEntity entity)
{
base.InitializeEntity(entity);
if (!entity.TryGetComponent(out ISpriteComponent? sprite))
return;
sprite.LayerMapSet(LayerMap, sprite.AddLayerState(_enabledState));
sprite.LayerSetVisible(LayerMap, false);
}
public override void OnChangeData(AppearanceComponent component) public override void OnChangeData(AppearanceComponent component)
{ {
base.OnChangeData(component); base.OnChangeData(component);
@@ -32,8 +23,8 @@ namespace Content.Client.Atmos.Visualizers
if (!component.Owner.TryGetComponent(out ISpriteComponent? sprite)) if (!component.Owner.TryGetComponent(out ISpriteComponent? sprite))
return; return;
if(component.TryGetData(DataKey, out bool enabled)) if(component.TryGetData(DataKey, out bool enabled) && sprite.LayerMapTryGet(LayerMap, out var layer))
sprite.LayerSetVisible(LayerMap, enabled); sprite.LayerSetState(layer, enabled ? _enabledState : _disabledState);
} }
} }
} }

View File

@@ -0,0 +1,18 @@
using System;
using Content.Shared.Atmos.Piping;
using JetBrains.Annotations;
namespace Content.Client.Atmos.Visualizers
{
[UsedImplicitly]
public class GasFilterVisualizer : EnabledAtmosDeviceVisualizer
{
protected override object LayerMap => Layers.Enabled;
protected override Enum DataKey => FilterVisuals.Enabled;
enum Layers : byte
{
Enabled,
}
}
}

View File

@@ -46,7 +46,7 @@ namespace Content.Client.Atmos.Visualizers
} }
} }
private enum Layers private enum Layers : byte
{ {
ConnectedToPort, ConnectedToPort,
} }

View File

@@ -10,7 +10,7 @@ namespace Content.Client.Atmos.Visualizers
protected override object LayerMap => Layers.Enabled; protected override object LayerMap => Layers.Enabled;
protected override Enum DataKey => OutletInjectorVisuals.Enabled; protected override Enum DataKey => OutletInjectorVisuals.Enabled;
enum Layers enum Layers : byte
{ {
Enabled, Enabled,
} }

View File

@@ -10,7 +10,7 @@ namespace Content.Client.Atmos.Visualizers
protected override object LayerMap => Layers.Enabled; protected override object LayerMap => Layers.Enabled;
protected override Enum DataKey => PassiveVentVisuals.Enabled; protected override Enum DataKey => PassiveVentVisuals.Enabled;
enum Layers enum Layers : byte
{ {
Enabled, Enabled,
} }

View File

@@ -10,7 +10,7 @@ namespace Content.Client.Atmos.Visualizers
protected override object LayerMap => Layers.Enabled; protected override object LayerMap => Layers.Enabled;
protected override Enum DataKey => PressurePumpVisuals.Enabled; protected override Enum DataKey => PressurePumpVisuals.Enabled;
enum Layers enum Layers : byte
{ {
Enabled, Enabled,
} }

View File

@@ -44,7 +44,7 @@ namespace Content.Client.Atmos.Visualizers
} }
} }
public enum ScrubberVisualLayers public enum ScrubberVisualLayers : byte
{ {
Scrubber, Scrubber,
} }

View File

@@ -10,7 +10,7 @@ namespace Content.Client.Atmos.Visualizers
protected override object LayerMap => Layers.Enabled; protected override object LayerMap => Layers.Enabled;
protected override Enum DataKey => ThermoMachineVisuals.Enabled; protected override Enum DataKey => ThermoMachineVisuals.Enabled;
enum Layers enum Layers : byte
{ {
Enabled, Enabled,
} }

View File

@@ -40,7 +40,7 @@ namespace Content.Client.Atmos.Visualizers
} }
} }
public enum VentVisualLayers public enum VentVisualLayers : byte
{ {
Vent, Vent,
} }

View File

@@ -3,7 +3,9 @@ using Content.Server.Atmos.Piping.Trinary.Components;
using Content.Server.NodeContainer; using Content.Server.NodeContainer;
using Content.Server.NodeContainer.Nodes; using Content.Server.NodeContainer.Nodes;
using Content.Shared.Atmos; using Content.Shared.Atmos;
using Content.Shared.Atmos.Piping;
using JetBrains.Annotations; using JetBrains.Annotations;
using Robust.Server.GameObjects;
using Robust.Shared.GameObjects; using Robust.Shared.GameObjects;
using Robust.Shared.IoC; using Robust.Shared.IoC;
using Robust.Shared.Timing; using Robust.Shared.Timing;
@@ -24,33 +26,35 @@ namespace Content.Server.Atmos.Piping.Trinary.EntitySystems
private void OnFilterUpdated(EntityUid uid, GasFilterComponent filter, AtmosDeviceUpdateEvent args) private void OnFilterUpdated(EntityUid uid, GasFilterComponent filter, AtmosDeviceUpdateEvent args)
{ {
if (!filter.Enabled) var appearance = filter.Owner.GetComponentOrNull<AppearanceComponent>();
return;
if (!ComponentManager.TryGetComponent(uid, out NodeContainerComponent? nodeContainer)) if (!filter.Enabled
return; || !ComponentManager.TryGetComponent(uid, out NodeContainerComponent? nodeContainer)
|| !ComponentManager.TryGetComponent(uid, out AtmosDeviceComponent? device)
if (!ComponentManager.TryGetComponent(uid, out AtmosDeviceComponent? device)) || !nodeContainer.TryGetNode(filter.InletName, out PipeNode? inletNode)
return;
if (!nodeContainer.TryGetNode(filter.InletName, out PipeNode? inletNode)
|| !nodeContainer.TryGetNode(filter.FilterName, out PipeNode? filterNode) || !nodeContainer.TryGetNode(filter.FilterName, out PipeNode? filterNode)
|| !nodeContainer.TryGetNode(filter.OutletName, out PipeNode? outletNode)) || !nodeContainer.TryGetNode(filter.OutletName, out PipeNode? outletNode)
|| outletNode.Air.Pressure >= Atmospherics.MaxOutputPressure) // No need to transfer if target is full.
{
appearance?.SetData(FilterVisuals.Enabled, false);
return; return;
}
if (outletNode.Air.Pressure >= Atmospherics.MaxOutputPressure)
return; // No need to transfer if target is full.
// We multiply the transfer rate in L/s by the seconds passed since the last process to get the liters. // We multiply the transfer rate in L/s by the seconds passed since the last process to get the liters.
var transferRatio = (float)(filter.TransferRate * (_gameTiming.CurTime - device.LastProcess).TotalSeconds) / inletNode.Air.Volume; var transferRatio = (float)(filter.TransferRate * (_gameTiming.CurTime - device.LastProcess).TotalSeconds) / inletNode.Air.Volume;
if (transferRatio <= 0) if (transferRatio <= 0)
{
appearance?.SetData(FilterVisuals.Enabled, false);
return; return;
}
var removed = inletNode.Air.RemoveRatio(transferRatio); var removed = inletNode.Air.RemoveRatio(transferRatio);
if (filter.FilteredGas.HasValue) if (filter.FilteredGas.HasValue)
{ {
appearance?.SetData(FilterVisuals.Enabled, true);
var filteredOut = new GasMixture() {Temperature = removed.Temperature}; var filteredOut = new GasMixture() {Temperature = removed.Temperature};
filteredOut.SetMoles(filter.FilteredGas.Value, removed.GetMoles(filter.FilteredGas.Value)); filteredOut.SetMoles(filter.FilteredGas.Value, removed.GetMoles(filter.FilteredGas.Value));

View File

@@ -4,31 +4,37 @@ using Robust.Shared.Serialization;
namespace Content.Shared.Atmos.Piping namespace Content.Shared.Atmos.Piping
{ {
[Serializable, NetSerializable] [Serializable, NetSerializable]
public enum OutletInjectorVisuals public enum OutletInjectorVisuals : byte
{ {
Enabled, Enabled,
} }
[Serializable, NetSerializable] [Serializable, NetSerializable]
public enum PassiveVentVisuals public enum PassiveVentVisuals : byte
{ {
Enabled, Enabled,
} }
[Serializable, NetSerializable] [Serializable, NetSerializable]
public enum VentScrubberVisuals public enum VentScrubberVisuals : byte
{ {
Enabled, Enabled,
} }
[Serializable, NetSerializable] [Serializable, NetSerializable]
public enum ThermoMachineVisuals public enum ThermoMachineVisuals : byte
{ {
Enabled, Enabled,
} }
[Serializable, NetSerializable] [Serializable, NetSerializable]
public enum PressurePumpVisuals public enum PressurePumpVisuals : byte
{
Enabled,
}
[Serializable, NetSerializable]
public enum FilterVisuals : byte
{ {
Enabled, Enabled,
} }

View File

@@ -33,13 +33,14 @@
state: pipeStraight state: pipeStraight
map: [ "enum.PipeColorVisualizer+Layers.Pipe" ] map: [ "enum.PipeColorVisualizer+Layers.Pipe" ]
- state: pumpPressure - state: pumpPressure
map: [ "enum.SubFloorShowLayerVisualizer+Layers.FirstLayer" ] map: [ "enum.SubFloorShowLayerVisualizer+Layers.FirstLayer", "enum.PressurePumpVisualizer+Layers.Enabled" ]
- type: Appearance - type: Appearance
visuals: visuals:
- type: SubFloorShowLayerVisualizer - type: SubFloorShowLayerVisualizer
- type: PipeConnectorVisualizer - type: PipeConnectorVisualizer
- type: PipeColorVisualizer - type: PipeColorVisualizer
- type: PressurePumpVisualizer - type: PressurePumpVisualizer
disabledState: pumpPressure
enabledState: pumpPressureOn enabledState: pumpPressureOn
- type: GasPressurePump - type: GasPressurePump

View File

@@ -38,12 +38,15 @@
state: pipeTJunction state: pipeTJunction
map: [ "enum.PipeColorVisualizer+Layers.Pipe" ] map: [ "enum.PipeColorVisualizer+Layers.Pipe" ]
- state: gasFilter - state: gasFilter
map: [ "enum.SubFloorShowLayerVisualizer+Layers.FirstLayer" ] map: [ "enum.SubFloorShowLayerVisualizer+Layers.FirstLayer", "enum.GasFilterVisualizer+Layers.Enabled" ]
- type: Appearance - type: Appearance
visuals: visuals:
- type: SubFloorShowLayerVisualizer - type: SubFloorShowLayerVisualizer
- type: PipeConnectorVisualizer - type: PipeConnectorVisualizer
- type: PipeColorVisualizer - type: PipeColorVisualizer
- type: GasFilterVisualizer
disabledState: gasFilter
enabledState: gasFilterOn
- type: GasFilter - type: GasFilter
- type: entity - type: entity

View File

@@ -148,6 +148,7 @@
- type: Sprite - type: Sprite
layers: layers:
- state: freezer_off - state: freezer_off
map: [ "enum.ThermoMachineVisualizer+Layers.Enabled" ]
- state: pipe - state: pipe
map: [ "enum.PipeColorVisualizer+Layers.Pipe" ] map: [ "enum.PipeColorVisualizer+Layers.Pipe" ]
- type: Appearance - type: Appearance
@@ -155,6 +156,7 @@
- type: PipeConnectorVisualizer - type: PipeConnectorVisualizer
- type: PipeColorVisualizer - type: PipeColorVisualizer
- type: ThermoMachineVisualizer - type: ThermoMachineVisualizer
disabledState: freezer_off
enabledState: freezer_on enabledState: freezer_on
- type: GasThermoMachine - type: GasThermoMachine
mode: Freezer mode: Freezer
@@ -170,6 +172,7 @@
- type: Sprite - type: Sprite
layers: layers:
- state: heater_off - state: heater_off
map: [ "enum.ThermoMachineVisualizer+Layers.Enabled" ]
- state: pipe - state: pipe
map: [ "enum.PipeColorVisualizer+Layers.Pipe" ] map: [ "enum.PipeColorVisualizer+Layers.Pipe" ]
- type: Appearance - type: Appearance
@@ -177,6 +180,7 @@
- type: PipeConnectorVisualizer - type: PipeConnectorVisualizer
- type: PipeColorVisualizer - type: PipeColorVisualizer
- type: ThermoMachineVisualizer - type: ThermoMachineVisualizer
disabledState: heater_off
enabledState: heater_on enabledState: heater_on
- type: GasThermoMachine - type: GasThermoMachine
mode: Heater mode: Heater

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

After

Width:  |  Height:  |  Size: 19 KiB