Gas injector visuals & balance (#8963)
This commit is contained in:
@@ -35,7 +35,8 @@ namespace Content.Server.Atmos.Piping.Binary.Components
|
|||||||
public float LowerThreshold { get; set; } = 0.01f;
|
public float LowerThreshold { get; set; } = 0.01f;
|
||||||
|
|
||||||
[DataField("higherThreshold")]
|
[DataField("higherThreshold")]
|
||||||
public float HigherThreshold { get; set; } = 2 * Atmospherics.MaxOutputPressure;
|
public float HigherThreshold { get; set; } = DefaultHigherThreshold;
|
||||||
|
public static readonly float DefaultHigherThreshold = 2 * Atmospherics.MaxOutputPressure;
|
||||||
|
|
||||||
[DataField("overclockThreshold")]
|
[DataField("overclockThreshold")]
|
||||||
public float OverclockThreshold { get; set; } = 1000;
|
public float OverclockThreshold { get; set; } = 1000;
|
||||||
|
|||||||
@@ -66,6 +66,8 @@ namespace Content.Server.Atmos.Piping.Binary.EntitySystems
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
appearance?.SetData(PumpVisuals.Enabled, true);
|
||||||
|
|
||||||
var inputStartingPressure = inlet.Air.Pressure;
|
var inputStartingPressure = inlet.Air.Pressure;
|
||||||
var outputStartingPressure = outlet.Air.Pressure;
|
var outputStartingPressure = outlet.Air.Pressure;
|
||||||
|
|
||||||
@@ -77,7 +79,6 @@ namespace Content.Server.Atmos.Piping.Binary.EntitySystems
|
|||||||
if ((outputStartingPressure - inputStartingPressure > pump.OverclockThreshold) && pump.Overclocked)
|
if ((outputStartingPressure - inputStartingPressure > pump.OverclockThreshold) && pump.Overclocked)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
appearance?.SetData(PumpVisuals.Enabled, true);
|
|
||||||
_ambientSoundSystem.SetAmbience(pump.Owner, true);
|
_ambientSoundSystem.SetAmbience(pump.Owner, true);
|
||||||
|
|
||||||
// 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.
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
using Content.Server.Atmos.Piping.Binary.Components;
|
||||||
using Content.Server.Atmos.Piping.Unary.EntitySystems;
|
using Content.Server.Atmos.Piping.Unary.EntitySystems;
|
||||||
using Content.Shared.Atmos;
|
using Content.Shared.Atmos;
|
||||||
|
|
||||||
@@ -11,9 +12,6 @@ namespace Content.Server.Atmos.Piping.Unary.Components
|
|||||||
[ViewVariables(VVAccess.ReadWrite)]
|
[ViewVariables(VVAccess.ReadWrite)]
|
||||||
public bool Enabled { get; set; } = true;
|
public bool Enabled { get; set; } = true;
|
||||||
|
|
||||||
[ViewVariables(VVAccess.ReadWrite)]
|
|
||||||
public bool Injecting { get; set; } = false;
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Target volume to transfer. If <see cref="WideNet"/> is enabled, actual transfer rate will be much higher.
|
/// Target volume to transfer. If <see cref="WideNet"/> is enabled, actual transfer rate will be much higher.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -31,7 +29,7 @@ namespace Content.Server.Atmos.Piping.Unary.Components
|
|||||||
public float MaxTransferRate = Atmospherics.MaxTransferRate;
|
public float MaxTransferRate = Atmospherics.MaxTransferRate;
|
||||||
|
|
||||||
[DataField("maxPressure")]
|
[DataField("maxPressure")]
|
||||||
public float MaxPressure { get; set; } = 2 * Atmospherics.MaxOutputPressure;
|
public float MaxPressure { get; set; } = GasVolumePumpComponent.DefaultHigherThreshold;
|
||||||
|
|
||||||
[DataField("inlet")]
|
[DataField("inlet")]
|
||||||
public string InletName { get; set; } = "pipe";
|
public string InletName { get; set; } = "pipe";
|
||||||
|
|||||||
@@ -3,6 +3,8 @@ using Content.Server.Atmos.Piping.Components;
|
|||||||
using Content.Server.Atmos.Piping.Unary.Components;
|
using Content.Server.Atmos.Piping.Unary.Components;
|
||||||
using Content.Server.NodeContainer;
|
using Content.Server.NodeContainer;
|
||||||
using Content.Server.NodeContainer.Nodes;
|
using Content.Server.NodeContainer.Nodes;
|
||||||
|
using Content.Shared.Atmos.Piping;
|
||||||
|
using Content.Shared.Interaction;
|
||||||
using JetBrains.Annotations;
|
using JetBrains.Annotations;
|
||||||
using Robust.Shared.Timing;
|
using Robust.Shared.Timing;
|
||||||
|
|
||||||
@@ -19,12 +21,31 @@ namespace Content.Server.Atmos.Piping.Unary.EntitySystems
|
|||||||
base.Initialize();
|
base.Initialize();
|
||||||
|
|
||||||
SubscribeLocalEvent<GasOutletInjectorComponent, AtmosDeviceUpdateEvent>(OnOutletInjectorUpdated);
|
SubscribeLocalEvent<GasOutletInjectorComponent, AtmosDeviceUpdateEvent>(OnOutletInjectorUpdated);
|
||||||
|
SubscribeLocalEvent<GasOutletInjectorComponent, ActivateInWorldEvent>(OnActivate);
|
||||||
|
SubscribeLocalEvent<GasOutletInjectorComponent, MapInitEvent>(OnMapInit);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnMapInit(EntityUid uid, GasOutletInjectorComponent component, MapInitEvent args)
|
||||||
|
{
|
||||||
|
UpdateAppearance(component);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnActivate(EntityUid uid, GasOutletInjectorComponent component, ActivateInWorldEvent args)
|
||||||
|
{
|
||||||
|
component.Enabled = !component.Enabled;
|
||||||
|
UpdateAppearance(component);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void UpdateAppearance(GasOutletInjectorComponent component, AppearanceComponent? appearance = null)
|
||||||
|
{
|
||||||
|
if (!Resolve(component.Owner, ref appearance, false))
|
||||||
|
return;
|
||||||
|
|
||||||
|
appearance.SetData(OutletInjectorVisuals.Enabled, component.Enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnOutletInjectorUpdated(EntityUid uid, GasOutletInjectorComponent injector, AtmosDeviceUpdateEvent args)
|
private void OnOutletInjectorUpdated(EntityUid uid, GasOutletInjectorComponent injector, AtmosDeviceUpdateEvent args)
|
||||||
{
|
{
|
||||||
injector.Injecting = false;
|
|
||||||
|
|
||||||
if (!injector.Enabled)
|
if (!injector.Enabled)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -45,7 +66,12 @@ namespace Content.Server.Atmos.Piping.Unary.EntitySystems
|
|||||||
if (inlet.Air.Temperature < 0)
|
if (inlet.Air.Temperature < 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (environment.Pressure > injector.MaxPressure)
|
||||||
|
return;
|
||||||
|
|
||||||
var timeDelta = (float) (_gameTiming.CurTime - device.LastProcess).TotalSeconds;
|
var timeDelta = (float) (_gameTiming.CurTime - device.LastProcess).TotalSeconds;
|
||||||
|
|
||||||
|
// TODO adjust ratio so that environment does not go above MaxPressure?
|
||||||
var ratio = MathF.Min(1f, timeDelta * injector.TransferRate / inlet.Air.Volume);
|
var ratio = MathF.Min(1f, timeDelta * injector.TransferRate / inlet.Air.Volume);
|
||||||
var removed = inlet.Air.RemoveRatio(ratio);
|
var removed = inlet.Air.RemoveRatio(ratio);
|
||||||
|
|
||||||
|
|||||||
@@ -139,15 +139,26 @@
|
|||||||
placement:
|
placement:
|
||||||
mode: SnapgridCenter
|
mode: SnapgridCenter
|
||||||
components:
|
components:
|
||||||
|
|
||||||
# TODO ATMOS: Actual sprite for this.
|
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
drawdepth: FloorObjects
|
drawdepth: FloorObjects
|
||||||
netsync: false
|
netsync: false
|
||||||
|
sprite: Structures/Piping/Atmospherics/outletinjector.rsi
|
||||||
layers:
|
layers:
|
||||||
- state: pipeHalf
|
- state: pipeHalf
|
||||||
sprite: Structures/Piping/Atmospherics/pipe.rsi
|
sprite: Structures/Piping/Atmospherics/pipe.rsi
|
||||||
map: [ "enum.PipeColorVisualizer+Layers.Pipe", "enum.SubfloorLayers.FirstLayer" ]
|
map: [ "enum.PipeColorVisualizer+Layers.Pipe", "enum.SubfloorLayers.FirstLayer" ]
|
||||||
|
- state: injector
|
||||||
|
- state: injector-unshaded
|
||||||
|
shader: unshaded
|
||||||
|
map: [ "unshaded" ]
|
||||||
|
color: "#990000"
|
||||||
|
- type: GenericVisualizer
|
||||||
|
visuals:
|
||||||
|
# toggle color of the unshaded light:
|
||||||
|
enum.OutletInjectorVisuals.Enabled:
|
||||||
|
unshaded:
|
||||||
|
True: { color: "#5eff5e" }
|
||||||
|
False: { color: "#990000" }
|
||||||
- type: Appearance
|
- type: Appearance
|
||||||
visuals:
|
visuals:
|
||||||
- type: PipeColorVisualizer
|
- type: PipeColorVisualizer
|
||||||
|
|||||||
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
Binary file not shown.
|
After Width: | Height: | Size: 906 B |
@@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
"version": 1,
|
||||||
|
"license": "CC-BY-SA-3.0",
|
||||||
|
"copyright": "injector state taken from https://github.com/tgstation/tgstation at commit 3e8407c4716bd8abcc79326f464384a5156eddfa.",
|
||||||
|
"size": {
|
||||||
|
"x": 32,
|
||||||
|
"y": 32
|
||||||
|
},
|
||||||
|
"states": [
|
||||||
|
{
|
||||||
|
"name": "injector",
|
||||||
|
"directions": 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "injector-unshaded",
|
||||||
|
"directions": 4
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user