Alert display lights now properly react to power changes. (#14839)

This commit is contained in:
Menshin
2023-03-25 04:10:48 +01:00
committed by GitHub
parent 76b5439dc3
commit 735701d915
3 changed files with 20 additions and 10 deletions

View File

@@ -15,32 +15,32 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
SubscribeLocalEvent<AlertLevelDisplayComponent, AppearanceChangeEvent>(OnAppearanceChange); SubscribeLocalEvent<AlertLevelDisplayComponent, AppearanceChangeEvent>(OnAppearanceChange);
} }
private void OnAppearanceChange(EntityUid uid, AlertLevelDisplayComponent component, ref AppearanceChangeEvent args) private void OnAppearanceChange(EntityUid uid, AlertLevelDisplayComponent alertLevelDisplay, ref AppearanceChangeEvent args)
{ {
if (args.Sprite == null) if (args.Sprite == null)
{ {
return; return;
} }
var layer = args.Sprite.LayerMapReserveBlank(AlertLevelDisplay.Layer);
if (!args.Sprite.LayerMapTryGet(AlertLevelDisplay.Layer, out _)) if (args.AppearanceData.TryGetValue(AlertLevelDisplay.Powered, out var poweredObject))
{ {
var layer = args.Sprite.AddLayer(new RSI.StateId(component.AlertVisuals.Values.First())); args.Sprite.LayerSetVisible(layer, poweredObject is true);
args.Sprite.LayerMapSet(AlertLevelDisplay.Layer, layer);
} }
if (!args.AppearanceData.TryGetValue(AlertLevelDisplay.CurrentLevel, out var level)) if (!args.AppearanceData.TryGetValue(AlertLevelDisplay.CurrentLevel, out var level))
{ {
args.Sprite.LayerSetState(AlertLevelDisplay.Layer, new RSI.StateId(component.AlertVisuals.Values.First())); args.Sprite.LayerSetState(layer, alertLevelDisplay.AlertVisuals.Values.First());
return; return;
} }
if (component.AlertVisuals.TryGetValue((string) level, out var visual)) if (alertLevelDisplay.AlertVisuals.TryGetValue((string) level, out var visual))
{ {
args.Sprite.LayerSetState(AlertLevelDisplay.Layer, new RSI.StateId(visual)); args.Sprite.LayerSetState(layer, visual);
} }
else else
{ {
args.Sprite.LayerSetState(AlertLevelDisplay.Layer, new RSI.StateId(component.AlertVisuals.Values.First())); args.Sprite.LayerSetState(layer, alertLevelDisplay.AlertVisuals.Values.First());
} }
} }
} }

View File

@@ -1,3 +1,4 @@
using Content.Server.Power.Components;
using Content.Server.Station.Systems; using Content.Server.Station.Systems;
using Content.Shared.AlertLevel; using Content.Shared.AlertLevel;
using Robust.Server.GameObjects; using Robust.Server.GameObjects;
@@ -13,6 +14,7 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
{ {
SubscribeLocalEvent<AlertLevelChangedEvent>(OnAlertChanged); SubscribeLocalEvent<AlertLevelChangedEvent>(OnAlertChanged);
SubscribeLocalEvent<AlertLevelDisplayComponent, ComponentInit>(OnDisplayInit); SubscribeLocalEvent<AlertLevelDisplayComponent, ComponentInit>(OnDisplayInit);
SubscribeLocalEvent<AlertLevelDisplayComponent, PowerChangedEvent>(OnPowerChanged);
} }
private void OnAlertChanged(AlertLevelChangedEvent args) private void OnAlertChanged(AlertLevelChangedEvent args)
@@ -23,7 +25,7 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
} }
} }
private void OnDisplayInit(EntityUid uid, AlertLevelDisplayComponent component, ComponentInit args) private void OnDisplayInit(EntityUid uid, AlertLevelDisplayComponent alertLevelDisplay, ComponentInit args)
{ {
if (TryComp(uid, out AppearanceComponent? appearance)) if (TryComp(uid, out AppearanceComponent? appearance))
{ {
@@ -34,4 +36,11 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
} }
} }
} }
private void OnPowerChanged(EntityUid uid, AlertLevelDisplayComponent alertLevelDisplay, ref PowerChangedEvent args)
{
if (!TryComp(uid, out AppearanceComponent? appearance))
return;
_appearance.SetData(uid, AlertLevelDisplay.Powered, args.Powered, appearance);
}
} }

View File

@@ -6,5 +6,6 @@ namespace Content.Shared.AlertLevel;
public enum AlertLevelDisplay public enum AlertLevelDisplay
{ {
CurrentLevel, CurrentLevel,
Layer Layer,
Powered
} }