* First pass * Fix access and rename banananium to bananium * Fix captialization of CookTimeInfoLabel * Fix InteractUsing calls * Remove unused [Dependency] * Replace obsolete references to Anchored with BodyType * Assign default value to shoving someone in disposals * Fix naming * Replace Initialize TryGetComponents with EnsureComponent * Rework AnchorableComponent * Fix singularity component * Replace obsolete usages of Angle.South * Fix efcore warning * Fix container tests * Fix DebugPressurePump invalid PressurePump yaml * Fix getting pathfinding region of grid 0 * Fix atmos plaque missing layer and add info message when it happens * Fix AiSteeringSystem steering in an invalid grid in entity test * Make content able to choose which log level leads to test failures * Revert container test fix for Acruid * Fix sprite, pipe and saving errors Make EntityTest print all errors instead of stopping on the first * Reorder singularity visualizer * Disable pvs for container occlusion adn simple predict reconcile, they use entities other than map ones Co-authored-by: Metal Gear Sloth <metalgearsloth@gmail.com> Co-authored-by: DrSmugleaf <DrSmugleaf@users.noreply.github.com> Co-authored-by: metalgearsloth <comedian_vs_clown@hotmail.com>
158 lines
4.9 KiB
C#
158 lines
4.9 KiB
C#
#nullable enable
|
|
using System.Linq;
|
|
using Content.Server.GameObjects.Components.StationEvents;
|
|
using Content.Shared.GameObjects.Components.Singularity;
|
|
using Robust.Server.GameObjects;
|
|
using Robust.Shared.Audio;
|
|
using Robust.Shared.Containers;
|
|
using Robust.Shared.GameObjects;
|
|
using Robust.Shared.Map;
|
|
using Robust.Shared.Physics;
|
|
using Robust.Shared.Physics.Collision;
|
|
using Robust.Shared.Physics.Collision.Shapes;
|
|
using Robust.Shared.Player;
|
|
using Robust.Shared.Players;
|
|
using Robust.Shared.Timing;
|
|
|
|
namespace Content.Server.GameObjects.Components.Singularity
|
|
{
|
|
[RegisterComponent]
|
|
public class ServerSingularityComponent : SharedSingularityComponent, IStartCollide
|
|
{
|
|
public int Energy
|
|
{
|
|
get => _energy;
|
|
set
|
|
{
|
|
if (value == _energy) return;
|
|
|
|
_energy = value;
|
|
if (_energy <= 0)
|
|
{
|
|
Owner.Delete();
|
|
return;
|
|
}
|
|
|
|
Level = _energy switch
|
|
{
|
|
var n when n >= 1500 => 6,
|
|
var n when n >= 1000 => 5,
|
|
var n when n >= 600 => 4,
|
|
var n when n >= 300 => 3,
|
|
var n when n >= 200 => 2,
|
|
var n when n < 200 => 1,
|
|
_ => 1
|
|
};
|
|
}
|
|
}
|
|
private int _energy = 180;
|
|
|
|
public int Level
|
|
{
|
|
get => _level;
|
|
set
|
|
{
|
|
if (value == _level) return;
|
|
if (value < 0) value = 0;
|
|
if (value > 6) value = 6;
|
|
|
|
_level = value;
|
|
|
|
if(_radiationPulseComponent != null) _radiationPulseComponent.RadsPerSecond = 10 * value;
|
|
|
|
if (Owner.TryGetComponent(out AppearanceComponent? appearance))
|
|
{
|
|
appearance.SetData(SingularityVisuals.Level, _level);
|
|
}
|
|
|
|
if (_collidableComponent != null && _collidableComponent.Fixtures.Any() && _collidableComponent.Fixtures[0].Shape is PhysShapeCircle circle)
|
|
{
|
|
circle.Radius = _level - 0.5f;
|
|
}
|
|
|
|
Dirty();
|
|
}
|
|
}
|
|
private int _level;
|
|
|
|
public int EnergyDrain =>
|
|
Level switch
|
|
{
|
|
6 => 20,
|
|
5 => 15,
|
|
4 => 10,
|
|
3 => 5,
|
|
2 => 2,
|
|
1 => 1,
|
|
_ => 0
|
|
};
|
|
|
|
private PhysicsComponent _collidableComponent = default!;
|
|
private RadiationPulseComponent _radiationPulseComponent = default!;
|
|
private SpriteComponent _spriteComponent = default!;
|
|
private IPlayingAudioStream? _playingSound;
|
|
|
|
public override ComponentState GetComponentState(ICommonSession player)
|
|
{
|
|
return new SingularityComponentState(Level);
|
|
}
|
|
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
|
|
Owner.EnsureComponent(out _radiationPulseComponent);
|
|
Owner.EnsureComponent(out _collidableComponent);
|
|
Owner.EnsureComponent(out _spriteComponent);
|
|
|
|
var audioParams = AudioParams.Default;
|
|
audioParams.Loop = true;
|
|
audioParams.MaxDistance = 20f;
|
|
audioParams.Volume = 5;
|
|
SoundSystem.Play(Filter.Pvs(Owner), "/Audio/Effects/singularity_form.ogg", Owner);
|
|
Timer.Spawn(5200,() => _playingSound = SoundSystem.Play(Filter.Pvs(Owner), "/Audio/Effects/singularity.ogg", Owner, audioParams));
|
|
|
|
_collidableComponent!.Hard = false;
|
|
Level = 1;
|
|
}
|
|
|
|
public void Update(int seconds)
|
|
{
|
|
Energy -= EnergyDrain * seconds;
|
|
}
|
|
|
|
void IStartCollide.CollideWith(IPhysBody ourBody, IPhysBody otherBody, in Manifold manifold)
|
|
{
|
|
var otherEntity = otherBody.Entity;
|
|
|
|
if (otherEntity.TryGetComponent<IMapGridComponent>(out var mapGridComponent))
|
|
{
|
|
foreach (var tile in mapGridComponent.Grid.GetTilesIntersecting(ourBody.GetWorldAABB()))
|
|
{
|
|
mapGridComponent.Grid.SetTile(tile.GridIndices, Tile.Empty);
|
|
Energy++;
|
|
}
|
|
return;
|
|
}
|
|
|
|
if (otherEntity.HasComponent<ContainmentFieldComponent>() || (otherEntity.TryGetComponent<ContainmentFieldGeneratorComponent>(out var component) && component.CanRepell(Owner)))
|
|
{
|
|
return;
|
|
}
|
|
|
|
if (otherEntity.IsInContainer())
|
|
return;
|
|
|
|
otherEntity.Delete();
|
|
Energy++;
|
|
}
|
|
|
|
public override void OnRemove()
|
|
{
|
|
_playingSound?.Stop();
|
|
SoundSystem.Play(Filter.Pvs(Owner), "/Audio/Effects/singularity_collapse.ogg", Owner.Transform.Coordinates);
|
|
base.OnRemove();
|
|
}
|
|
}
|
|
}
|