GasFilter appearance, EnabledAtmosDeviceVisualizer improvements.
This commit is contained in:
@@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
18
Content.Client/Atmos/Visualizers/GasFilterVisualizer.cs
Normal file
18
Content.Client/Atmos/Visualizers/GasFilterVisualizer.cs
Normal 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,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -46,7 +46,7 @@ namespace Content.Client.Atmos.Visualizers
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private enum Layers
|
private enum Layers : byte
|
||||||
{
|
{
|
||||||
ConnectedToPort,
|
ConnectedToPort,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -44,7 +44,7 @@ namespace Content.Client.Atmos.Visualizers
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ScrubberVisualLayers
|
public enum ScrubberVisualLayers : byte
|
||||||
{
|
{
|
||||||
Scrubber,
|
Scrubber,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ namespace Content.Client.Atmos.Visualizers
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum VentVisualLayers
|
public enum VentVisualLayers : byte
|
||||||
{
|
{
|
||||||
Vent,
|
Vent,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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));
|
||||||
|
|||||||
@@ -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,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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 |
Reference in New Issue
Block a user