Optimize ExtensionCableSystem (#6158)
This commit is contained in:
@@ -25,7 +25,8 @@ namespace Content.Server.Power.EntitySystems
|
|||||||
SubscribeLocalEvent<ExtensionCableReceiverComponent, ComponentShutdown>(OnReceiverShutdown);
|
SubscribeLocalEvent<ExtensionCableReceiverComponent, ComponentShutdown>(OnReceiverShutdown);
|
||||||
|
|
||||||
//Anchoring
|
//Anchoring
|
||||||
SubscribeLocalEvent<ExtensionCableReceiverComponent, AnchorStateChangedEvent>(AnchorStateChanged);
|
SubscribeLocalEvent<ExtensionCableReceiverComponent, AnchorStateChangedEvent>(OnReceiverAnchorStateChanged);
|
||||||
|
SubscribeLocalEvent<ExtensionCableProviderComponent, AnchorStateChangedEvent>(OnProviderAnchorStateChanged);
|
||||||
}
|
}
|
||||||
|
|
||||||
#region Provider
|
#region Provider
|
||||||
@@ -65,9 +66,34 @@ namespace Content.Server.Power.EntitySystems
|
|||||||
ResetReceivers(provider);
|
ResetReceivers(provider);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnProviderAnchorStateChanged(EntityUid uid, ExtensionCableProviderComponent provider, ref AnchorStateChangedEvent args)
|
||||||
|
{
|
||||||
|
if (args.Anchored)
|
||||||
|
{
|
||||||
|
provider.Connectable = true;
|
||||||
|
|
||||||
|
// same as OnProviderStarted
|
||||||
|
foreach (var receiver in FindAvailableReceivers(uid, provider.TransferRange))
|
||||||
|
{
|
||||||
|
receiver.Provider?.LinkedReceivers.Remove(receiver);
|
||||||
|
receiver.Provider = provider;
|
||||||
|
provider.LinkedReceivers.Add(receiver);
|
||||||
|
RaiseLocalEvent(receiver.Owner, new ProviderConnectedEvent(provider), broadcast: false);
|
||||||
|
RaiseLocalEvent(uid, new ReceiverConnectedEvent(receiver), broadcast: false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// same as OnProviderShutdown
|
||||||
|
provider.Connectable = false;
|
||||||
|
ResetReceivers(provider);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void ResetReceivers(ExtensionCableProviderComponent provider)
|
private void ResetReceivers(ExtensionCableProviderComponent provider)
|
||||||
{
|
{
|
||||||
var receivers = provider.LinkedReceivers.ToArray();
|
var receivers = provider.LinkedReceivers.ToArray();
|
||||||
|
provider.LinkedReceivers.Clear();
|
||||||
|
|
||||||
foreach (var receiver in receivers)
|
foreach (var receiver in receivers)
|
||||||
{
|
{
|
||||||
@@ -80,9 +106,11 @@ namespace Content.Server.Power.EntitySystems
|
|||||||
{
|
{
|
||||||
// No point resetting what the receiver is doing if it's deleting, plus significant perf savings
|
// No point resetting what the receiver is doing if it's deleting, plus significant perf savings
|
||||||
// in not doing needless lookups
|
// in not doing needless lookups
|
||||||
if (MetaData(receiver.Owner).EntityLifeStage > EntityLifeStage.MapInitialized) continue;
|
if (!EntityManager.IsQueuedForDeletion(receiver.Owner)
|
||||||
|
&& MetaData(receiver.Owner).EntityLifeStage <= EntityLifeStage.MapInitialized)
|
||||||
TryFindAndSetProvider(receiver);
|
{
|
||||||
|
TryFindAndSetProvider(receiver);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -91,19 +119,26 @@ namespace Content.Server.Power.EntitySystems
|
|||||||
var xform = Transform(owner);
|
var xform = Transform(owner);
|
||||||
var coordinates = xform.Coordinates;
|
var coordinates = xform.Coordinates;
|
||||||
|
|
||||||
var nearbyEntities = _lookup.GetEntitiesInRange(coordinates, range);
|
if (!_mapManager.TryGetGrid(xform.GridID, out var grid))
|
||||||
|
yield break;
|
||||||
|
|
||||||
|
var nearbyEntities = grid.GetCellsInSquareArea(coordinates, (int) Math.Ceiling(range / grid.TileSize));
|
||||||
|
|
||||||
foreach (var entity in nearbyEntities)
|
foreach (var entity in nearbyEntities)
|
||||||
{
|
{
|
||||||
if (entity != owner &&
|
if (entity == owner) continue;
|
||||||
EntityManager.TryGetComponent<ExtensionCableReceiverComponent>(entity, out var receiver) &&
|
|
||||||
receiver.Connectable &&
|
if (EntityManager.IsQueuedForDeletion(entity) || MetaData(entity).EntityLifeStage > EntityLifeStage.MapInitialized)
|
||||||
receiver.Provider == null &&
|
continue;
|
||||||
Transform(entity).Coordinates.TryDistance(EntityManager, coordinates, out var distance) &&
|
|
||||||
distance < Math.Min(range, receiver.ReceptionRange))
|
if (!TryComp(entity, out ExtensionCableReceiverComponent? receiver))
|
||||||
{
|
continue;
|
||||||
|
|
||||||
|
if (!receiver.Connectable || receiver.Provider != null)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if ((Transform(entity).LocalPosition - xform.LocalPosition).Length < Math.Min(range, receiver.ReceptionRange))
|
||||||
yield return receiver;
|
yield return receiver;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -152,7 +187,7 @@ namespace Content.Server.Power.EntitySystems
|
|||||||
RaiseLocalEvent(receiver.Provider.Owner, new ReceiverDisconnectedEvent(receiver), broadcast: false);
|
RaiseLocalEvent(receiver.Provider.Owner, new ReceiverDisconnectedEvent(receiver), broadcast: false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void AnchorStateChanged(EntityUid uid, ExtensionCableReceiverComponent receiver, ref AnchorStateChangedEvent args)
|
private void OnReceiverAnchorStateChanged(EntityUid uid, ExtensionCableReceiverComponent receiver, ref AnchorStateChangedEvent args)
|
||||||
{
|
{
|
||||||
if (args.Anchored)
|
if (args.Anchored)
|
||||||
{
|
{
|
||||||
@@ -178,6 +213,8 @@ namespace Content.Server.Power.EntitySystems
|
|||||||
|
|
||||||
private void TryFindAndSetProvider(ExtensionCableReceiverComponent receiver, TransformComponent? xform = null)
|
private void TryFindAndSetProvider(ExtensionCableReceiverComponent receiver, TransformComponent? xform = null)
|
||||||
{
|
{
|
||||||
|
if (!receiver.Connectable) return;
|
||||||
|
|
||||||
if (!TryFindAvailableProvider(receiver.Owner, receiver.ReceptionRange, out var provider, xform)) return;
|
if (!TryFindAvailableProvider(receiver.Owner, receiver.ReceptionRange, out var provider, xform)) return;
|
||||||
|
|
||||||
receiver.Provider = provider;
|
receiver.Provider = provider;
|
||||||
@@ -188,24 +225,26 @@ namespace Content.Server.Power.EntitySystems
|
|||||||
|
|
||||||
private bool TryFindAvailableProvider(EntityUid owner, float range, [NotNullWhen(true)] out ExtensionCableProviderComponent? foundProvider, TransformComponent? xform = null)
|
private bool TryFindAvailableProvider(EntityUid owner, float range, [NotNullWhen(true)] out ExtensionCableProviderComponent? foundProvider, TransformComponent? xform = null)
|
||||||
{
|
{
|
||||||
if (!Resolve(owner, ref xform))
|
if (!Resolve(owner, ref xform) || !_mapManager.TryGetGrid(xform.GridID, out var grid))
|
||||||
{
|
{
|
||||||
foundProvider = null;
|
foundProvider = null;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
var coordinates = xform.Coordinates;
|
var coordinates = xform.Coordinates;
|
||||||
var nearbyEntities = _lookup.GetEntitiesInRange(coordinates, range);
|
var nearbyEntities = grid.GetCellsInSquareArea(coordinates, (int) Math.Ceiling(range / grid.TileSize));
|
||||||
|
|
||||||
foreach (var entity in nearbyEntities)
|
foreach (var entity in nearbyEntities)
|
||||||
{
|
{
|
||||||
if (entity == owner || !EntityManager.TryGetComponent<ExtensionCableProviderComponent?>(entity, out var provider)) continue;
|
if (entity == owner || !EntityManager.TryGetComponent<ExtensionCableProviderComponent?>(entity, out var provider)) continue;
|
||||||
|
|
||||||
|
if (EntityManager.IsQueuedForDeletion(entity)) continue;
|
||||||
|
|
||||||
|
if (MetaData(entity).EntityLifeStage > EntityLifeStage.MapInitialized) continue;
|
||||||
|
|
||||||
if (!provider.Connectable) continue;
|
if (!provider.Connectable) continue;
|
||||||
|
|
||||||
if (!Transform(entity).Coordinates.TryDistance(EntityManager, coordinates, out var distance)) continue;
|
if ((Transform(entity).LocalPosition - xform.LocalPosition).Length > Math.Min(range, provider.TransferRange)) continue;
|
||||||
|
|
||||||
if (!(distance < Math.Min(range, provider.TransferRange))) continue;
|
|
||||||
|
|
||||||
foundProvider = provider;
|
foundProvider = provider;
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -2,6 +2,8 @@
|
|||||||
name: cell recharger
|
name: cell recharger
|
||||||
id: PowerCellRecharger
|
id: PowerCellRecharger
|
||||||
components:
|
components:
|
||||||
|
- type: Transform
|
||||||
|
anchored: true
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
netsync: false
|
netsync: false
|
||||||
sprite: Structures/Power/cell_recharger.rsi
|
sprite: Structures/Power/cell_recharger.rsi
|
||||||
|
|||||||
@@ -4,6 +4,8 @@
|
|||||||
description: "An unpowered light."
|
description: "An unpowered light."
|
||||||
suffix: Unpowered
|
suffix: Unpowered
|
||||||
components:
|
components:
|
||||||
|
- type: Transform
|
||||||
|
anchored: true
|
||||||
- type: Clickable
|
- type: Clickable
|
||||||
- type: InteractionOutline
|
- type: InteractionOutline
|
||||||
- type: Construction
|
- type: Construction
|
||||||
|
|||||||
@@ -54,6 +54,8 @@
|
|||||||
- type: Clickable
|
- type: Clickable
|
||||||
- type: InteractionOutline
|
- type: InteractionOutline
|
||||||
- type: Physics
|
- type: Physics
|
||||||
|
- type: Transform
|
||||||
|
anchored: true
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Structures/Wallmounts/switch.rsi
|
sprite: Structures/Wallmounts/switch.rsi
|
||||||
state: on
|
state: on
|
||||||
|
|||||||
@@ -7,6 +7,8 @@
|
|||||||
- type: InteractionOutline
|
- type: InteractionOutline
|
||||||
- type: Physics
|
- type: Physics
|
||||||
bodyType: Static
|
bodyType: Static
|
||||||
|
- type: Transform
|
||||||
|
anchored: true
|
||||||
- type: Fixtures
|
- type: Fixtures
|
||||||
fixtures:
|
fixtures:
|
||||||
- shape:
|
- shape:
|
||||||
|
|||||||
Reference in New Issue
Block a user