Gas injector visuals & balance (#8963)
This commit is contained in:
@@ -3,6 +3,8 @@ using Content.Server.Atmos.Piping.Components;
|
||||
using Content.Server.Atmos.Piping.Unary.Components;
|
||||
using Content.Server.NodeContainer;
|
||||
using Content.Server.NodeContainer.Nodes;
|
||||
using Content.Shared.Atmos.Piping;
|
||||
using Content.Shared.Interaction;
|
||||
using JetBrains.Annotations;
|
||||
using Robust.Shared.Timing;
|
||||
|
||||
@@ -19,12 +21,31 @@ namespace Content.Server.Atmos.Piping.Unary.EntitySystems
|
||||
base.Initialize();
|
||||
|
||||
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)
|
||||
{
|
||||
injector.Injecting = false;
|
||||
|
||||
if (!injector.Enabled)
|
||||
return;
|
||||
|
||||
@@ -45,7 +66,12 @@ namespace Content.Server.Atmos.Piping.Unary.EntitySystems
|
||||
if (inlet.Air.Temperature < 0)
|
||||
return;
|
||||
|
||||
if (environment.Pressure > injector.MaxPressure)
|
||||
return;
|
||||
|
||||
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 removed = inlet.Air.RemoveRatio(ratio);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user