mirror of
https://github.com/WWhiteDreamProject/wwdpublic.git
synced 2026-04-17 13:37:47 +03:00
<!-- This is a semi-strict format, you can add/remove sections as needed but the order/format should be kept the same Remove these comments before submitting --> # Description the adding AI is now up to y'all because i'm not touching loadout code for name datasets, but it shouldn't be too bad from here --------- Signed-off-by: sleepyyapril <123355664+sleepyyapril@users.noreply.github.com> Signed-off-by: SolStar <44028047+ewokswagger@users.noreply.github.com> Signed-off-by: deltanedas <39013340+deltanedas@users.noreply.github.com> Co-authored-by: themias <89101928+themias@users.noreply.github.com> Co-authored-by: Verm <32827189+Vermidia@users.noreply.github.com> Co-authored-by: DrSmugleaf <10968691+DrSmugleaf@users.noreply.github.com> Co-authored-by: Sphiral <145869023+SphiraI@users.noreply.github.com> Co-authored-by: Ed <96445749+TheShuEd@users.noreply.github.com> Co-authored-by: Mr. 27 <45323883+Dutch-VanDerLinde@users.noreply.github.com> Co-authored-by: metalgearsloth <comedian_vs_clown@hotmail.com> Co-authored-by: Alzore <140123969+Blackern5000@users.noreply.github.com> Co-authored-by: ravage <142820619+ravage123321@users.noreply.github.com> Co-authored-by: slarticodefast <161409025+slarticodefast@users.noreply.github.com> Co-authored-by: Intoxicating-Innocence <188202277+Intoxicating-Innocence@users.noreply.github.com> Co-authored-by: Saphire <lattice@saphi.re> Co-authored-by: metalgearsloth <31366439+metalgearsloth@users.noreply.github.com> Co-authored-by: Errant <35878406+Errant-4@users.noreply.github.com> Co-authored-by: Tayrtahn <tayrtahn@gmail.com> Co-authored-by: CaasGit <87243814+CaasGit@users.noreply.github.com> Co-authored-by: BramvanZijp <56019239+BramvanZijp@users.noreply.github.com> Co-authored-by: Boaz1111 <149967078+Boaz1111@users.noreply.github.com> Co-authored-by: NakataRin <45946146+NakataRin@users.noreply.github.com> Co-authored-by: Kara <lunarautomaton6@gmail.com> Co-authored-by: Plykiya <58439124+Plykiya@users.noreply.github.com> Co-authored-by: SlamBamActionman <slambamactionman@gmail.com> Co-authored-by: Doomsdrayk <robotdoughnut@comcast.net> Co-authored-by: Brandon Hu <103440971+Brandon-Huu@users.noreply.github.com> Co-authored-by: SlamBamActionman <83650252+SlamBamActionman@users.noreply.github.com> Co-authored-by: ElectroJr <leonsfriedrich@gmail.com> Co-authored-by: Pieter-Jan Briers <pieterjan.briers+git@gmail.com> Co-authored-by: DrSmugleaf <DrSmugleaf@users.noreply.github.com> Co-authored-by: Julian Giebel <juliangiebel@live.de> Co-authored-by: nikthechampiongr <32041239+nikthechampiongr@users.noreply.github.com> Co-authored-by: Repo <47093363+Titian3@users.noreply.github.com> Co-authored-by: Chief-Engineer <119664036+Chief-Engineer@users.noreply.github.com> Co-authored-by: icekot8 <93311212+icekot8@users.noreply.github.com> Co-authored-by: AJCM-git <60196617+AJCM-git@users.noreply.github.com> Co-authored-by: Leon Friedrich <60421075+ElectroJr@users.noreply.github.com> Co-authored-by: no <165581243+pissdemon@users.noreply.github.com> Co-authored-by: Tornado Tech <54727692+Tornado-Technology@users.noreply.github.com> Co-authored-by: osjarw <62134478+osjarw@users.noreply.github.com> Co-authored-by: Simon <63975668+Simyon264@users.noreply.github.com> Co-authored-by: TGRCDev <tgrc@tgrc.dev> Co-authored-by: Milon <milonpl.git@proton.me> Co-authored-by: deltanedas <39013340+deltanedas@users.noreply.github.com> Co-authored-by: ShadowCommander <10494922+ShadowCommander@users.noreply.github.com> Co-authored-by: Fildrance <fildrance@gmail.com> Co-authored-by: pa.pecherskij <pa.pecherskij@interfax.ru> Co-authored-by: chavonadelal <156101927+chavonadelal@users.noreply.github.com> Co-authored-by: SolStar <44028047+ewokswagger@users.noreply.github.com> Co-authored-by: K-Dynamic <20566341+K-Dynamic@users.noreply.github.com> Co-authored-by: lzk <124214523+lzk228@users.noreply.github.com> Co-authored-by: ArchRBX <5040911+ArchRBX@users.noreply.github.com> Co-authored-by: archrbx <punk.gear5260@fastmail.com> Co-authored-by: Radezolid <snappednexus@gmail.com> Co-authored-by: Nemanja <98561806+EmoGarbage404@users.noreply.github.com> Co-authored-by: EmoGarbage404 <retron404@gmail.com> Co-authored-by: MilenVolf <63782763+MilenVolf@users.noreply.github.com> Co-authored-by: Velcroboy <107660393+IamVelcroboy@users.noreply.github.com> Co-authored-by: Velcroboy <velcroboy333@hotmail.com> Co-authored-by: neuPanda <chriseparton@gmail.com> Co-authored-by: neuPanda <spainman0@yahoo.com> Co-authored-by: Dvir <39403717+dvir001@users.noreply.github.com> Co-authored-by: Whatstone <whatston3@gmail.com> Co-authored-by: VideoKompany <135313844+VlaDOS1408@users.noreply.github.com> (cherry picked from commit 93ed70acfeda357133a701f637d3faeec02749bb)
201 lines
7.5 KiB
C#
201 lines
7.5 KiB
C#
using Content.Server.Anomaly.Components;
|
|
using Content.Server.Power.Components;
|
|
using Content.Server.Power.EntitySystems;
|
|
using Content.Server.Station.Components;
|
|
using Content.Shared.Anomaly;
|
|
using Content.Shared.CCVar;
|
|
using Content.Shared.Materials;
|
|
using Content.Shared.Radio;
|
|
using Robust.Shared.Audio;
|
|
using Content.Shared.Physics;
|
|
using Robust.Shared.Map.Components;
|
|
using Robust.Shared.Physics;
|
|
using Robust.Shared.Physics.Components;
|
|
using Robust.Shared.Map;
|
|
using System.Numerics;
|
|
using Content.Shared.Power;
|
|
using Robust.Server.GameObjects;
|
|
|
|
namespace Content.Server.Anomaly;
|
|
|
|
/// <summary>
|
|
/// This handles anomalous vessel as well as
|
|
/// the calculations for how many points they
|
|
/// should produce.
|
|
/// </summary>
|
|
public sealed partial class AnomalySystem
|
|
{
|
|
[Dependency] private readonly SharedMapSystem _mapSystem = default!;
|
|
[Dependency] private readonly SharedTransformSystem _transform = default!;
|
|
|
|
private void InitializeGenerator()
|
|
{
|
|
SubscribeLocalEvent<AnomalyGeneratorComponent, BoundUIOpenedEvent>(OnGeneratorBUIOpened);
|
|
SubscribeLocalEvent<AnomalyGeneratorComponent, MaterialAmountChangedEvent>(OnGeneratorMaterialAmountChanged);
|
|
SubscribeLocalEvent<AnomalyGeneratorComponent, AnomalyGeneratorGenerateButtonPressedEvent>(OnGenerateButtonPressed);
|
|
SubscribeLocalEvent<AnomalyGeneratorComponent, PowerChangedEvent>(OnGeneratorPowerChanged);
|
|
SubscribeLocalEvent<GeneratingAnomalyGeneratorComponent, ComponentStartup>(OnGeneratingStartup);
|
|
}
|
|
|
|
private void OnGeneratorPowerChanged(EntityUid uid, AnomalyGeneratorComponent component, ref PowerChangedEvent args)
|
|
{
|
|
_ambient.SetAmbience(uid, args.Powered);
|
|
}
|
|
|
|
private void OnGeneratorBUIOpened(EntityUid uid, AnomalyGeneratorComponent component, BoundUIOpenedEvent args)
|
|
{
|
|
UpdateGeneratorUi(uid, component);
|
|
}
|
|
|
|
private void OnGeneratorMaterialAmountChanged(EntityUid uid, AnomalyGeneratorComponent component, ref MaterialAmountChangedEvent args)
|
|
{
|
|
UpdateGeneratorUi(uid, component);
|
|
}
|
|
|
|
private void OnGenerateButtonPressed(EntityUid uid, AnomalyGeneratorComponent component, AnomalyGeneratorGenerateButtonPressedEvent args)
|
|
{
|
|
TryGeneratorCreateAnomaly(uid, component);
|
|
}
|
|
|
|
public void UpdateGeneratorUi(EntityUid uid, AnomalyGeneratorComponent component)
|
|
{
|
|
var materialAmount = _material.GetMaterialAmount(uid, component.RequiredMaterial);
|
|
|
|
var state = new AnomalyGeneratorUserInterfaceState(component.CooldownEndTime, materialAmount, component.MaterialPerAnomaly);
|
|
_ui.SetUiState(uid, AnomalyGeneratorUiKey.Key, state);
|
|
}
|
|
|
|
public void TryGeneratorCreateAnomaly(EntityUid uid, AnomalyGeneratorComponent? component = null)
|
|
{
|
|
if (!Resolve(uid, ref component))
|
|
return;
|
|
|
|
if (!this.IsPowered(uid, EntityManager))
|
|
return;
|
|
|
|
if (Timing.CurTime < component.CooldownEndTime)
|
|
return;
|
|
|
|
if (!_material.TryChangeMaterialAmount(uid, component.RequiredMaterial, -component.MaterialPerAnomaly))
|
|
return;
|
|
|
|
var generating = EnsureComp<GeneratingAnomalyGeneratorComponent>(uid);
|
|
generating.EndTime = Timing.CurTime + component.GenerationLength;
|
|
generating.AudioStream = Audio.PlayPvs(component.GeneratingSound, uid, AudioParams.Default.WithLoop(true))?.Entity;
|
|
component.CooldownEndTime = Timing.CurTime + component.CooldownLength;
|
|
UpdateGeneratorUi(uid, component);
|
|
}
|
|
|
|
public void SpawnOnRandomGridLocation(EntityUid grid, string toSpawn)
|
|
{
|
|
if (!TryComp<MapGridComponent>(grid, out var gridComp))
|
|
return;
|
|
|
|
var xform = Transform(grid);
|
|
|
|
var targetCoords = xform.Coordinates;
|
|
var gridBounds = gridComp.LocalAABB.Scale(_configuration.GetCVar(CCVars.AnomalyGenerationGridBoundsScale));
|
|
|
|
for (var i = 0; i < 25; i++)
|
|
{
|
|
var randomX = Random.Next((int) gridBounds.Left, (int) gridBounds.Right);
|
|
var randomY = Random.Next((int) gridBounds.Bottom, (int)gridBounds.Top);
|
|
|
|
var tile = new Vector2i(randomX, randomY);
|
|
|
|
// no air-blocked areas.
|
|
if (_atmosphere.IsTileSpace(grid, xform.MapUid, tile) ||
|
|
_atmosphere.IsTileAirBlocked(grid, tile, mapGridComp: gridComp))
|
|
{
|
|
continue;
|
|
}
|
|
|
|
// don't spawn inside of solid objects
|
|
var physQuery = GetEntityQuery<PhysicsComponent>();
|
|
var valid = true;
|
|
|
|
// TODO: This should be using static lookup.
|
|
foreach (var ent in gridComp.GetAnchoredEntities(tile))
|
|
{
|
|
if (!physQuery.TryGetComponent(ent, out var body))
|
|
continue;
|
|
if (body.BodyType != BodyType.Static ||
|
|
!body.Hard ||
|
|
(body.CollisionLayer & (int) CollisionGroup.Impassable) == 0)
|
|
continue;
|
|
|
|
valid = false;
|
|
break;
|
|
}
|
|
if (!valid)
|
|
continue;
|
|
|
|
var pos = _mapSystem.GridTileToLocal(grid, gridComp, tile);
|
|
var mapPos = pos.ToMap(EntityManager, _transform);
|
|
// don't spawn in AntiAnomalyZones
|
|
var antiAnomalyZonesQueue = AllEntityQuery<AntiAnomalyZoneComponent, TransformComponent>();
|
|
while (antiAnomalyZonesQueue.MoveNext(out var uid, out var zone, out var antiXform))
|
|
{
|
|
if (antiXform.MapID != mapPos.MapId)
|
|
continue;
|
|
|
|
var antiCoordinates = _transform.GetWorldPosition(antiXform);
|
|
|
|
var delta = antiCoordinates - mapPos.Position;
|
|
if (delta.LengthSquared() < zone.ZoneRadius * zone.ZoneRadius)
|
|
{
|
|
valid = false;
|
|
break;
|
|
}
|
|
}
|
|
if (!valid)
|
|
continue;
|
|
|
|
targetCoords = pos;
|
|
break;
|
|
}
|
|
|
|
Spawn(toSpawn, targetCoords);
|
|
}
|
|
|
|
private void OnGeneratingStartup(EntityUid uid, GeneratingAnomalyGeneratorComponent component, ComponentStartup args)
|
|
{
|
|
Appearance.SetData(uid, AnomalyGeneratorVisuals.Generating, true);
|
|
}
|
|
|
|
private void OnGeneratingFinished(EntityUid uid, AnomalyGeneratorComponent component)
|
|
{
|
|
var xform = Transform(uid);
|
|
|
|
if (_station.GetStationInMap(xform.MapID) is not { } station ||
|
|
!TryComp<StationDataComponent>(station, out var data) ||
|
|
_station.GetLargestGrid(data) is not { } grid)
|
|
{
|
|
if (xform.GridUid == null)
|
|
return;
|
|
grid = xform.GridUid.Value;
|
|
}
|
|
|
|
SpawnOnRandomGridLocation(grid, component.SpawnerPrototype);
|
|
RemComp<GeneratingAnomalyGeneratorComponent>(uid);
|
|
Appearance.SetData(uid, AnomalyGeneratorVisuals.Generating, false);
|
|
Audio.PlayPvs(component.GeneratingFinishedSound, uid);
|
|
|
|
var message = Loc.GetString("anomaly-generator-announcement");
|
|
_radio.SendRadioMessage(uid, message, _prototype.Index<RadioChannelPrototype>(component.ScienceChannel), uid);
|
|
}
|
|
|
|
private void UpdateGenerator()
|
|
{
|
|
var query = EntityQueryEnumerator<GeneratingAnomalyGeneratorComponent, AnomalyGeneratorComponent>();
|
|
while (query.MoveNext(out var ent, out var active, out var gen))
|
|
{
|
|
if (Timing.CurTime < active.EndTime)
|
|
continue;
|
|
|
|
active.AudioStream = _audio.Stop(active.AudioStream);
|
|
OnGeneratingFinished(ent, gen);
|
|
}
|
|
}
|
|
}
|