-
Notifications
You must be signed in to change notification settings - Fork 359
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add magnet pickup system from Frontier (#949)
* Add magnet pickup system from Frontier * No wl needed here * Add translation strings * Making code optimizations, missing component on upgraded smelter * Update lathe.yml --------- Co-authored-by: Velcroboy <> Co-authored-by: VMSolidus <[email protected]>
- Loading branch information
1 parent
7abdf9a
commit 5acb90a
Showing
7 changed files
with
264 additions
and
0 deletions.
There are no files selected for viewing
20 changes: 20 additions & 0 deletions
20
Content.Shared/Frontier/Storage/Components/MaterialReclaimerMagnetPickupComponent.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
namespace Content.Shared.Frontier.Storage.Components; | ||
|
||
/// <summary> | ||
/// Applies an ongoing pickup area around the attached entity. | ||
/// </summary> | ||
[RegisterComponent] | ||
public sealed partial class MaterialReclaimerMagnetPickupComponent : Component | ||
{ | ||
[ViewVariables(VVAccess.ReadWrite), DataField("nextScan")] | ||
public TimeSpan NextScan = TimeSpan.Zero; | ||
|
||
[ViewVariables(VVAccess.ReadWrite), DataField("range")] | ||
public float Range = 1f; | ||
|
||
/// <summary> | ||
/// Frontier - Is the magnet currently enabled? | ||
/// </summary> | ||
[ViewVariables(VVAccess.ReadWrite), DataField("magnetEnabled")] | ||
public bool MagnetEnabled = false; | ||
} |
20 changes: 20 additions & 0 deletions
20
Content.Shared/Frontier/Storage/Components/MaterialStorageMagnetPickupComponent.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
namespace Content.Shared.Frontier.Storage.Components; | ||
|
||
/// <summary> | ||
/// Applies an ongoing pickup area around the attached entity. | ||
/// </summary> | ||
[RegisterComponent] | ||
public sealed partial class MaterialStorageMagnetPickupComponent : Component | ||
{ | ||
[ViewVariables(VVAccess.ReadWrite), DataField("nextScan")] | ||
public TimeSpan NextScan = TimeSpan.Zero; | ||
|
||
[ViewVariables(VVAccess.ReadWrite), DataField("range")] | ||
public float Range = 1f; | ||
|
||
/// <summary> | ||
/// Frontier - Is the magnet currently enabled? | ||
/// </summary> | ||
[ViewVariables(VVAccess.ReadWrite), DataField("magnetEnabled")] | ||
public bool MagnetEnabled = false; | ||
} |
107 changes: 107 additions & 0 deletions
107
Content.Shared/Frontier/Storage/EntitySystems/MaterialReclaimerMagnetPickupSystem.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
using Content.Shared.Frontier.Storage.Components; | ||
using Content.Shared.Materials; | ||
using Robust.Shared.Physics.Components; | ||
using Robust.Shared.Timing; | ||
using Content.Shared.Examine; // Frontier | ||
using Content.Shared.Hands.Components; // Frontier | ||
using Content.Shared.Verbs; // Frontier | ||
using Robust.Shared.Utility; // Frontier | ||
|
||
namespace Content.Shared.Frontier.Storage.EntitySystems; | ||
|
||
/// <summary> | ||
/// <see cref="MaterialReclaimerMagnetPickupComponent"/> | ||
/// </summary> | ||
public sealed class MaterialReclaimerMagnetPickupSystem : EntitySystem | ||
{ | ||
[Dependency] private readonly IGameTiming _timing = default!; | ||
[Dependency] private readonly EntityLookupSystem _lookup = default!; | ||
[Dependency] private readonly SharedMaterialReclaimerSystem _storage = default!; | ||
|
||
private static readonly TimeSpan ScanDelay = TimeSpan.FromSeconds(1); | ||
|
||
private EntityQuery<PhysicsComponent> _physicsQuery; | ||
|
||
public override void Initialize() | ||
{ | ||
base.Initialize(); | ||
_physicsQuery = GetEntityQuery<PhysicsComponent>(); | ||
SubscribeLocalEvent<MaterialReclaimerMagnetPickupComponent, MapInitEvent>(OnMagnetMapInit); | ||
SubscribeLocalEvent<MaterialReclaimerMagnetPickupComponent, EntityUnpausedEvent>(OnMagnetUnpaused); | ||
SubscribeLocalEvent<MaterialReclaimerMagnetPickupComponent, ExaminedEvent>(OnExamined); // Frontier | ||
SubscribeLocalEvent<MaterialReclaimerMagnetPickupComponent, GetVerbsEvent<AlternativeVerb>>(AddToggleMagnetVerb); // Frontier | ||
} | ||
|
||
private void OnMagnetUnpaused(EntityUid uid, MaterialReclaimerMagnetPickupComponent component, ref EntityUnpausedEvent args) | ||
{ | ||
component.NextScan += args.PausedTime; | ||
} | ||
|
||
private void OnMagnetMapInit(EntityUid uid, MaterialReclaimerMagnetPickupComponent component, MapInitEvent args) | ||
{ | ||
component.NextScan = _timing.CurTime + TimeSpan.FromSeconds(1); // Need to add 1 sec to fix a weird time bug with it that make it never start the magnet | ||
} | ||
|
||
// Frontier, used to add the magnet toggle to the context menu | ||
private void AddToggleMagnetVerb(EntityUid uid, MaterialReclaimerMagnetPickupComponent component, GetVerbsEvent<AlternativeVerb> args) | ||
{ | ||
if (!HasComp<HandsComponent>(args.User) | ||
|| !args.CanInteract | ||
|| !args.CanAccess) | ||
return; | ||
|
||
AlternativeVerb verb = new() | ||
{ | ||
Act = () => | ||
{ | ||
component.MagnetEnabled = !component.MagnetEnabled; | ||
}, | ||
Icon = new SpriteSpecifier.Texture(new("/Textures/Interface/VerbIcons/Spare/poweronoff.svg.192dpi.png")), | ||
Text = Loc.GetString("magnet-pickup-component-toggle-verb"), | ||
Priority = 3 | ||
}; | ||
|
||
args.Verbs.Add(verb); | ||
} | ||
|
||
// Frontier, used to show the magnet state on examination | ||
private void OnExamined(EntityUid uid, MaterialReclaimerMagnetPickupComponent component, ExaminedEvent args) | ||
{ | ||
args.PushMarkup(Loc.GetString("magnet-pickup-component-on-examine-main", | ||
("stateText", Loc.GetString(component.MagnetEnabled | ||
? "magnet-pickup-component-magnet-on" | ||
: "magnet-pickup-component-magnet-off")))); | ||
} | ||
|
||
public override void Update(float frameTime) | ||
{ | ||
base.Update(frameTime); | ||
var query = EntityQueryEnumerator<MaterialReclaimerMagnetPickupComponent, MaterialReclaimerComponent, TransformComponent>(); | ||
var currentTime = _timing.CurTime; | ||
|
||
while (query.MoveNext(out var uid, out var comp, out var storage, out var xform)) | ||
{ | ||
if (comp.NextScan < currentTime) | ||
continue; | ||
|
||
comp.NextScan += ScanDelay; | ||
|
||
// Frontier - magnet disabled | ||
if (!comp.MagnetEnabled) | ||
continue; | ||
|
||
var parentUid = xform.ParentUid; | ||
|
||
foreach (var near in _lookup.GetEntitiesInRange(uid, comp.Range, LookupFlags.Dynamic | LookupFlags.Sundries)) | ||
{ | ||
if (!_physicsQuery.TryGetComponent(near, out var physics) || physics.BodyStatus != BodyStatus.OnGround) | ||
continue; | ||
|
||
if (near == parentUid) | ||
continue; | ||
|
||
_storage.TryStartProcessItem(uid, near); | ||
} | ||
} | ||
} | ||
} |
107 changes: 107 additions & 0 deletions
107
Content.Shared/Frontier/Storage/EntitySystems/MaterialStorageMagnetPickupSystem.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
using Content.Shared.Frontier.Storage.Components; | ||
using Content.Shared.Materials; | ||
using Robust.Shared.Physics.Components; | ||
using Robust.Shared.Timing; | ||
using Content.Shared.Examine; // Frontier | ||
using Content.Shared.Hands.Components; // Frontier | ||
using Content.Shared.Verbs; // Frontier | ||
using Robust.Shared.Utility; // Frontier | ||
|
||
namespace Content.Shared.Frontier.Storage.EntitySystems; | ||
|
||
/// <summary> | ||
/// <see cref="MaterialStorageMagnetPickupComponent"/> | ||
/// </summary> | ||
public sealed class MaterialStorageMagnetPickupSystem : EntitySystem | ||
{ | ||
[Dependency] private readonly IGameTiming _timing = default!; | ||
[Dependency] private readonly EntityLookupSystem _lookup = default!; | ||
[Dependency] private readonly SharedMaterialStorageSystem _storage = default!; | ||
|
||
private static readonly TimeSpan ScanDelay = TimeSpan.FromSeconds(1); | ||
|
||
private EntityQuery<PhysicsComponent> _physicsQuery; | ||
|
||
public override void Initialize() | ||
{ | ||
base.Initialize(); | ||
_physicsQuery = GetEntityQuery<PhysicsComponent>(); | ||
SubscribeLocalEvent<MaterialStorageMagnetPickupComponent, MapInitEvent>(OnMagnetMapInit); | ||
SubscribeLocalEvent<MaterialStorageMagnetPickupComponent, EntityUnpausedEvent>(OnMagnetUnpaused); | ||
SubscribeLocalEvent<MaterialStorageMagnetPickupComponent, ExaminedEvent>(OnExamined); // Frontier | ||
SubscribeLocalEvent<MaterialStorageMagnetPickupComponent, GetVerbsEvent<AlternativeVerb>>(AddToggleMagnetVerb); // Frontier | ||
} | ||
|
||
private void OnMagnetUnpaused(EntityUid uid, MaterialStorageMagnetPickupComponent component, ref EntityUnpausedEvent args) | ||
{ | ||
component.NextScan += args.PausedTime; | ||
} | ||
|
||
private void OnMagnetMapInit(EntityUid uid, MaterialStorageMagnetPickupComponent component, MapInitEvent args) | ||
{ | ||
component.NextScan = _timing.CurTime + TimeSpan.FromSeconds(1); // Need to add 1 sec to fix a weird time bug with it that make it never start the magnet | ||
} | ||
|
||
// Frontier, used to add the magnet toggle to the context menu | ||
private void AddToggleMagnetVerb(EntityUid uid, MaterialStorageMagnetPickupComponent component, GetVerbsEvent<AlternativeVerb> args) | ||
{ | ||
if (!HasComp<HandsComponent>(args.User) | ||
|| !args.CanInteract | ||
|| !args.CanAccess) | ||
return; | ||
|
||
AlternativeVerb verb = new() | ||
{ | ||
Act = () => | ||
{ | ||
component.MagnetEnabled = !component.MagnetEnabled; | ||
}, | ||
Icon = new SpriteSpecifier.Texture(new("/Textures/Interface/VerbIcons/Spare/poweronoff.svg.192dpi.png")), | ||
Text = Loc.GetString("magnet-pickup-component-toggle-verb"), | ||
Priority = 3 | ||
}; | ||
|
||
args.Verbs.Add(verb); | ||
} | ||
|
||
// Frontier, used to show the magnet state on examination | ||
private void OnExamined(EntityUid uid, MaterialStorageMagnetPickupComponent component, ExaminedEvent args) | ||
{ | ||
args.PushMarkup(Loc.GetString("magnet-pickup-component-on-examine-main", | ||
("stateText", Loc.GetString(component.MagnetEnabled | ||
? "magnet-pickup-component-magnet-on" | ||
: "magnet-pickup-component-magnet-off")))); | ||
} | ||
|
||
public override void Update(float frameTime) | ||
{ | ||
base.Update(frameTime); | ||
var query = EntityQueryEnumerator<MaterialStorageMagnetPickupComponent, MaterialStorageComponent, TransformComponent>(); | ||
var currentTime = _timing.CurTime; | ||
|
||
while (query.MoveNext(out var uid, out var comp, out var storage, out var xform)) | ||
{ | ||
if (comp.NextScan < currentTime) | ||
continue; | ||
|
||
comp.NextScan += ScanDelay; | ||
|
||
// Frontier - magnet disabled | ||
if (!comp.MagnetEnabled) | ||
continue; | ||
|
||
var parentUid = xform.ParentUid; | ||
|
||
foreach (var near in _lookup.GetEntitiesInRange(uid, comp.Range, LookupFlags.Dynamic | LookupFlags.Sundries)) | ||
{ | ||
if (!_physicsQuery.TryGetComponent(near, out var physics) || physics.BodyStatus != BodyStatus.OnGround) | ||
continue; | ||
|
||
if (near == parentUid) | ||
continue; | ||
|
||
_storage.TryInsertMaterialEntity(uid, near, uid, storage); | ||
} | ||
} | ||
} | ||
} |
4 changes: 4 additions & 0 deletions
4
Resources/Locale/en-US/frontier/storage/components/magnet-pickup-components.ftl
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
magnet-pickup-component-toggle-verb = Toggle magnet | ||
magnet-pickup-component-on-examine-main = The magnet appears to be {$stateText}. | ||
magnet-pickup-component-magnet-on = [color=darkgreen]on[/color] | ||
magnet-pickup-component-magnet-off = [color=darkred]off[/color] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters