* Atmos device performance improvements * AtmosDirection perf improvements * Fix errors * Add GasTileOverlayComponent arguments * Make excite no longer invalidate a tile
59 lines
2.0 KiB
C#
59 lines
2.0 KiB
C#
using Content.Server.NodeContainer;
|
|
using Content.Server.NodeContainer.EntitySystems;
|
|
using Content.Server.Power.Components;
|
|
using Content.Server.Power.Nodes;
|
|
using Content.Shared.Wires;
|
|
using JetBrains.Annotations;
|
|
using Robust.Shared.Map.Components;
|
|
|
|
namespace Content.Server.Power.EntitySystems
|
|
{
|
|
[UsedImplicitly]
|
|
public sealed class CableVisSystem : EntitySystem
|
|
{
|
|
[Dependency] private readonly SharedAppearanceSystem _appearance = default!;
|
|
[Dependency] private readonly NodeContainerSystem _nodeContainer = default!;
|
|
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
|
|
SubscribeLocalEvent<CableVisComponent, NodeGroupsRebuilt>(UpdateAppearance);
|
|
}
|
|
|
|
private void UpdateAppearance(EntityUid uid, CableVisComponent cableVis, ref NodeGroupsRebuilt args)
|
|
{
|
|
if (!_nodeContainer.TryGetNode(uid, cableVis.Node, out CableNode? node))
|
|
return;
|
|
|
|
var transform = Transform(uid);
|
|
if (!TryComp<MapGridComponent>(transform.GridUid, out var grid))
|
|
return;
|
|
|
|
var mask = WireVisDirFlags.None;
|
|
var tile = grid.TileIndicesFor(transform.Coordinates);
|
|
|
|
foreach (var reachable in node.ReachableNodes)
|
|
{
|
|
if (reachable is not CableNode)
|
|
continue;
|
|
|
|
var otherTransform = Transform(reachable.Owner);
|
|
var otherTile = grid.TileIndicesFor(otherTransform.Coordinates);
|
|
var diff = otherTile - tile;
|
|
|
|
mask |= diff switch
|
|
{
|
|
(0, 1) => WireVisDirFlags.North,
|
|
(0, -1) => WireVisDirFlags.South,
|
|
(1, 0) => WireVisDirFlags.East,
|
|
(-1, 0) => WireVisDirFlags.West,
|
|
_ => WireVisDirFlags.None
|
|
};
|
|
}
|
|
|
|
_appearance.SetData(uid, WireVisVisuals.ConnectedMask, mask);
|
|
}
|
|
}
|
|
}
|