Alert display lights now properly react to power changes. (#14839)
This commit is contained in:
@@ -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());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,5 +6,6 @@ namespace Content.Shared.AlertLevel;
|
|||||||
public enum AlertLevelDisplay
|
public enum AlertLevelDisplay
|
||||||
{
|
{
|
||||||
CurrentLevel,
|
CurrentLevel,
|
||||||
Layer
|
Layer,
|
||||||
|
Powered
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user