Refactors throw events, makes cream pies ECS (#4500)
This commit is contained in:
committed by
GitHub
parent
140682f92b
commit
ea4ce1c6fc
@@ -179,8 +179,6 @@ namespace Content.Client.Entry
|
|||||||
"StorageCounter",
|
"StorageCounter",
|
||||||
"SpaceVillainArcade",
|
"SpaceVillainArcade",
|
||||||
"Flammable",
|
"Flammable",
|
||||||
"CreamPie",
|
|
||||||
"CreamPied",
|
|
||||||
"Smoking",
|
"Smoking",
|
||||||
"Matchstick",
|
"Matchstick",
|
||||||
"Matchbox",
|
"Matchbox",
|
||||||
|
|||||||
10
Content.Client/Nutrition/EntitySystems/CreamPiedSystem.cs
Normal file
10
Content.Client/Nutrition/EntitySystems/CreamPiedSystem.cs
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
using Content.Shared.Nutrition.EntitySystems;
|
||||||
|
using JetBrains.Annotations;
|
||||||
|
|
||||||
|
namespace Content.Client.Nutrition.EntitySystems
|
||||||
|
{
|
||||||
|
[UsedImplicitly]
|
||||||
|
public class CreamPiedSystem : SharedCreamPieSystem
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,7 +1,9 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Content.Server.Nutrition.Components;
|
using Content.Server.Nutrition.Components;
|
||||||
|
using Content.Server.Nutrition.EntitySystems;
|
||||||
using Content.Shared.Chemistry.Reagent;
|
using Content.Shared.Chemistry.Reagent;
|
||||||
using Content.Shared.Chemistry.Solution;
|
using Content.Shared.Chemistry.Solution;
|
||||||
|
using Content.Shared.Nutrition.Components;
|
||||||
using JetBrains.Annotations;
|
using JetBrains.Annotations;
|
||||||
using Robust.Shared.GameObjects;
|
using Robust.Shared.GameObjects;
|
||||||
using Robust.Shared.Serialization.Manager.Attributes;
|
using Robust.Shared.Serialization.Manager.Attributes;
|
||||||
@@ -20,7 +22,7 @@ namespace Content.Server.Chemistry.ReagentEntityReactions
|
|||||||
{
|
{
|
||||||
if (!entity.TryGetComponent(out CreamPiedComponent? creamPied) || !_reagents.Contains(reagent.ID)) return;
|
if (!entity.TryGetComponent(out CreamPiedComponent? creamPied) || !_reagents.Contains(reagent.ID)) return;
|
||||||
|
|
||||||
creamPied.Wash();
|
EntitySystem.Get<CreamPieSystem>().SetCreamPied(entity.Uid, creamPied, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,28 +1,23 @@
|
|||||||
using Content.Shared.Damage;
|
using Content.Shared.Damage;
|
||||||
using Content.Shared.Damage.Components;
|
using Robust.Shared.Analyzers;
|
||||||
using Content.Shared.Throwing;
|
|
||||||
using Robust.Shared.GameObjects;
|
using Robust.Shared.GameObjects;
|
||||||
using Robust.Shared.Serialization.Manager.Attributes;
|
using Robust.Shared.Serialization.Manager.Attributes;
|
||||||
|
|
||||||
namespace Content.Server.Damage.Components
|
namespace Content.Server.Damage.Components
|
||||||
{
|
{
|
||||||
|
[Friend(typeof(DamageOtherOnHitSystem))]
|
||||||
[RegisterComponent]
|
[RegisterComponent]
|
||||||
public class DamageOtherOnHitComponent : Component, IThrowCollide
|
public class DamageOtherOnHitComponent : Component
|
||||||
{
|
{
|
||||||
public override string Name => "DamageOtherOnHit";
|
public override string Name => "DamageOtherOnHit";
|
||||||
|
|
||||||
[DataField("damageType")]
|
[DataField("damageType")]
|
||||||
private DamageType _damageType = DamageType.Blunt;
|
public DamageType DamageType { get; } = DamageType.Blunt;
|
||||||
|
|
||||||
[DataField("amount")]
|
[DataField("amount")]
|
||||||
private int _amount = 1;
|
public int Amount { get; } = 1;
|
||||||
|
|
||||||
[DataField("ignoreResistances")]
|
[DataField("ignoreResistances")]
|
||||||
private bool _ignoreResistances;
|
public bool IgnoreResistances { get; } = false;
|
||||||
|
|
||||||
void IThrowCollide.DoHit(ThrowCollideEventArgs eventArgs)
|
|
||||||
{
|
|
||||||
if (!eventArgs.Target.TryGetComponent(out IDamageableComponent? damageable)) return;
|
|
||||||
|
|
||||||
damageable.ChangeDamage(_damageType, _amount, _ignoreResistances, eventArgs.User);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
23
Content.Server/Damage/DamageOtherOnHitSystem.cs
Normal file
23
Content.Server/Damage/DamageOtherOnHitSystem.cs
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
using Content.Server.Damage.Components;
|
||||||
|
using Content.Shared.Damage.Components;
|
||||||
|
using Content.Shared.Throwing;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Server.Damage
|
||||||
|
{
|
||||||
|
public class DamageOtherOnHitSystem : EntitySystem
|
||||||
|
{
|
||||||
|
public override void Initialize()
|
||||||
|
{
|
||||||
|
SubscribeLocalEvent<DamageOtherOnHitComponent, ThrowDoHitEvent>(OnDoHit);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnDoHit(EntityUid uid, DamageOtherOnHitComponent component, ThrowDoHitEvent args)
|
||||||
|
{
|
||||||
|
if (!args.Target.TryGetComponent(out IDamageableComponent? damageable))
|
||||||
|
return;
|
||||||
|
|
||||||
|
damageable.ChangeDamage(component.DamageType, component.Amount, component.IgnoreResistances, args.User);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,8 +1,10 @@
|
|||||||
using Content.Server.Atmos.Components;
|
using Content.Server.Atmos.Components;
|
||||||
using Content.Server.Nutrition.Components;
|
using Content.Server.Nutrition.Components;
|
||||||
|
using Content.Server.Nutrition.EntitySystems;
|
||||||
using Content.Server.Stunnable.Components;
|
using Content.Server.Stunnable.Components;
|
||||||
using Content.Shared.Damage.Components;
|
using Content.Shared.Damage.Components;
|
||||||
using Content.Shared.MobState;
|
using Content.Shared.MobState;
|
||||||
|
using Content.Shared.Nutrition.Components;
|
||||||
using Content.Shared.Verbs;
|
using Content.Shared.Verbs;
|
||||||
using Robust.Server.Console;
|
using Robust.Server.Console;
|
||||||
using Robust.Server.GameObjects;
|
using Robust.Server.GameObjects;
|
||||||
@@ -89,7 +91,7 @@ namespace Content.Server.Damage
|
|||||||
|
|
||||||
if (target.TryGetComponent(out CreamPiedComponent? creamPied))
|
if (target.TryGetComponent(out CreamPiedComponent? creamPied))
|
||||||
{
|
{
|
||||||
creamPied.Wash();
|
EntitySystem.Get<CreamPieSystem>().SetCreamPied(target.Uid, creamPied, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ namespace Content.Server.Disposal.Unit.EntitySystems
|
|||||||
SubscribeLocalEvent<DisposalUnitComponent, ComponentInit>(HandleDisposalInit);
|
SubscribeLocalEvent<DisposalUnitComponent, ComponentInit>(HandleDisposalInit);
|
||||||
SubscribeLocalEvent<DisposalUnitComponent, ComponentShutdown>(HandleDisposalShutdown);
|
SubscribeLocalEvent<DisposalUnitComponent, ComponentShutdown>(HandleDisposalShutdown);
|
||||||
|
|
||||||
SubscribeLocalEvent<DisposalUnitComponent, ThrowCollideEvent>(HandleThrowCollide);
|
SubscribeLocalEvent<DisposalUnitComponent, ThrowHitByEvent>(HandleThrowCollide);
|
||||||
|
|
||||||
// Interactions
|
// Interactions
|
||||||
SubscribeLocalEvent<DisposalUnitComponent, ActivateInWorldEvent>(HandleActivate);
|
SubscribeLocalEvent<DisposalUnitComponent, ActivateInWorldEvent>(HandleActivate);
|
||||||
@@ -144,7 +144,7 @@ namespace Content.Server.Disposal.Unit.EntitySystems
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Thrown items have a chance of bouncing off the unit and not going in.
|
/// Thrown items have a chance of bouncing off the unit and not going in.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private void HandleThrowCollide(EntityUid uid, DisposalUnitComponent component, ThrowCollideEvent args)
|
private void HandleThrowCollide(EntityUid uid, DisposalUnitComponent component, ThrowHitByEvent args)
|
||||||
{
|
{
|
||||||
if (!CanInsert(component, args.Thrown) ||
|
if (!CanInsert(component, args.Thrown) ||
|
||||||
_robustRandom.NextDouble() > 0.75 ||
|
_robustRandom.NextDouble() > 0.75 ||
|
||||||
|
|||||||
@@ -1,53 +0,0 @@
|
|||||||
using Content.Server.Chemistry.Components;
|
|
||||||
using Content.Server.Fluids.Components;
|
|
||||||
using Content.Shared.Audio;
|
|
||||||
using Content.Shared.Sound;
|
|
||||||
using Content.Shared.Throwing;
|
|
||||||
using Robust.Shared.Audio;
|
|
||||||
using Robust.Shared.GameObjects;
|
|
||||||
using Robust.Shared.Player;
|
|
||||||
using Robust.Shared.Serialization.Manager.Attributes;
|
|
||||||
using Robust.Shared.ViewVariables;
|
|
||||||
|
|
||||||
namespace Content.Server.Nutrition.Components
|
|
||||||
{
|
|
||||||
[RegisterComponent]
|
|
||||||
public class CreamPieComponent : Component, ILand, IThrowCollide
|
|
||||||
{
|
|
||||||
public override string Name => "CreamPie";
|
|
||||||
|
|
||||||
[ViewVariables(VVAccess.ReadWrite)]
|
|
||||||
[DataField("paralyzeTime")]
|
|
||||||
public float ParalyzeTime { get; set; } = 1f;
|
|
||||||
|
|
||||||
[DataField("sound")]
|
|
||||||
private SoundSpecifier _sound = new SoundCollectionSpecifier("desecration");
|
|
||||||
|
|
||||||
public void PlaySound()
|
|
||||||
{
|
|
||||||
SoundSystem.Play(Filter.Pvs(Owner), _sound.GetSound(), Owner, AudioHelpers.WithVariation(0.125f));
|
|
||||||
}
|
|
||||||
|
|
||||||
void IThrowCollide.DoHit(ThrowCollideEventArgs eventArgs)
|
|
||||||
{
|
|
||||||
Splat();
|
|
||||||
}
|
|
||||||
|
|
||||||
void ILand.Land(LandEventArgs eventArgs)
|
|
||||||
{
|
|
||||||
Splat();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Splat()
|
|
||||||
{
|
|
||||||
PlaySound();
|
|
||||||
|
|
||||||
if (Owner.TryGetComponent(out SolutionContainerComponent? solution))
|
|
||||||
{
|
|
||||||
solution.Solution.SpillAt(Owner, "PuddleSmear", false);
|
|
||||||
}
|
|
||||||
|
|
||||||
Owner.QueueDelete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,55 +0,0 @@
|
|||||||
using Content.Server.Notification;
|
|
||||||
using Content.Server.Stunnable.Components;
|
|
||||||
using Content.Shared.Notification;
|
|
||||||
using Content.Shared.Notification.Managers;
|
|
||||||
using Content.Shared.Nutrition.Components;
|
|
||||||
using Content.Shared.Throwing;
|
|
||||||
using Robust.Server.GameObjects;
|
|
||||||
using Robust.Shared.GameObjects;
|
|
||||||
using Robust.Shared.Localization;
|
|
||||||
using Robust.Shared.ViewVariables;
|
|
||||||
|
|
||||||
namespace Content.Server.Nutrition.Components
|
|
||||||
{
|
|
||||||
[RegisterComponent]
|
|
||||||
public class CreamPiedComponent : SharedCreamPiedComponent, IThrowCollide
|
|
||||||
{
|
|
||||||
private bool _creamPied;
|
|
||||||
|
|
||||||
[ViewVariables]
|
|
||||||
public bool CreamPied
|
|
||||||
{
|
|
||||||
get => _creamPied;
|
|
||||||
private set
|
|
||||||
{
|
|
||||||
if (value == _creamPied) return;
|
|
||||||
|
|
||||||
_creamPied = value;
|
|
||||||
if (Owner.TryGetComponent(out AppearanceComponent? appearance))
|
|
||||||
{
|
|
||||||
appearance.SetData(CreamPiedVisuals.Creamed, CreamPied);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Wash()
|
|
||||||
{
|
|
||||||
if(CreamPied)
|
|
||||||
CreamPied = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void IThrowCollide.HitBy(ThrowCollideEventArgs eventArgs)
|
|
||||||
{
|
|
||||||
if (eventArgs.Thrown.Deleted || !eventArgs.Thrown.TryGetComponent(out CreamPieComponent? creamPie)) return;
|
|
||||||
|
|
||||||
CreamPied = true;
|
|
||||||
Owner.PopupMessage(Loc.GetString("cream-pied-component-on-hit-by-message",("thrower", eventArgs.Thrown)));
|
|
||||||
Owner.PopupMessageOtherClients(Loc.GetString("cream-pied-component-on-hit-by-message-others", ("owner", Owner),("thrower", eventArgs.Thrown)));
|
|
||||||
|
|
||||||
if (Owner.TryGetComponent(out StunnableComponent? stun))
|
|
||||||
{
|
|
||||||
stun.Paralyze(creamPie.ParalyzeTime);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
36
Content.Server/Nutrition/EntitySystems/CreamPieSystem.cs
Normal file
36
Content.Server/Nutrition/EntitySystems/CreamPieSystem.cs
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
using Content.Server.Chemistry.Components;
|
||||||
|
using Content.Server.Fluids.Components;
|
||||||
|
using Content.Server.Notification;
|
||||||
|
using Content.Shared.Audio;
|
||||||
|
using Content.Shared.Notification.Managers;
|
||||||
|
using Content.Shared.Nutrition.Components;
|
||||||
|
using Content.Shared.Nutrition.EntitySystems;
|
||||||
|
using Content.Shared.Throwing;
|
||||||
|
using JetBrains.Annotations;
|
||||||
|
using Robust.Shared.Audio;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
using Robust.Shared.Player;
|
||||||
|
|
||||||
|
namespace Content.Server.Nutrition.EntitySystems
|
||||||
|
{
|
||||||
|
[UsedImplicitly]
|
||||||
|
public class CreamPieSystem : SharedCreamPieSystem
|
||||||
|
{
|
||||||
|
protected override void SplattedCreamPie(EntityUid uid, CreamPieComponent creamPie)
|
||||||
|
{
|
||||||
|
SoundSystem.Play(Filter.Pvs(creamPie.Owner), creamPie.Sound.GetSound(), creamPie.Owner, AudioHelpers.WithVariation(0.125f));
|
||||||
|
|
||||||
|
if (ComponentManager.TryGetComponent(uid, out SolutionContainerComponent? solution))
|
||||||
|
{
|
||||||
|
solution.Solution.SpillAt(creamPie.Owner, "PuddleSmear", false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void CreamedEntity(EntityUid uid, CreamPiedComponent creamPied, ThrowHitByEvent args)
|
||||||
|
{
|
||||||
|
creamPied.Owner.PopupMessage(Loc.GetString("cream-pied-component-on-hit-by-message",("thrower", args.Thrown)));
|
||||||
|
creamPied.Owner.PopupMessageOtherClients(Loc.GetString("cream-pied-component-on-hit-by-message-others", ("owner", creamPied.Owner),("thrower", args.Thrown)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -31,7 +31,7 @@ namespace Content.Server.Stunnable
|
|||||||
SubscribeLocalEvent<StunbatonComponent, MeleeHitEvent>(OnMeleeHit);
|
SubscribeLocalEvent<StunbatonComponent, MeleeHitEvent>(OnMeleeHit);
|
||||||
SubscribeLocalEvent<StunbatonComponent, MeleeInteractEvent>(OnMeleeInteract);
|
SubscribeLocalEvent<StunbatonComponent, MeleeInteractEvent>(OnMeleeInteract);
|
||||||
SubscribeLocalEvent<StunbatonComponent, UseInHandEvent>(OnUseInHand);
|
SubscribeLocalEvent<StunbatonComponent, UseInHandEvent>(OnUseInHand);
|
||||||
SubscribeLocalEvent<StunbatonComponent, ThrowCollideEvent>(OnThrowCollide);
|
SubscribeLocalEvent<StunbatonComponent, ThrowDoHitEvent>(OnThrowCollide);
|
||||||
SubscribeLocalEvent<StunbatonComponent, PowerCellChangedEvent>(OnPowerCellChanged);
|
SubscribeLocalEvent<StunbatonComponent, PowerCellChangedEvent>(OnPowerCellChanged);
|
||||||
SubscribeLocalEvent<StunbatonComponent, InteractUsingEvent>(OnInteractUsing);
|
SubscribeLocalEvent<StunbatonComponent, InteractUsingEvent>(OnInteractUsing);
|
||||||
SubscribeLocalEvent<StunbatonComponent, ExaminedEvent>(OnExamined);
|
SubscribeLocalEvent<StunbatonComponent, ExaminedEvent>(OnExamined);
|
||||||
@@ -81,7 +81,7 @@ namespace Content.Server.Stunnable
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnThrowCollide(EntityUid uid, StunbatonComponent comp, ThrowCollideEvent args)
|
private void OnThrowCollide(EntityUid uid, StunbatonComponent comp, ThrowDoHitEvent args)
|
||||||
{
|
{
|
||||||
if (!ComponentManager.TryGetComponent<PowerCellSlotComponent>(uid, out var slot)) return;
|
if (!ComponentManager.TryGetComponent<PowerCellSlotComponent>(uid, out var slot)) return;
|
||||||
if (!comp.Activated || slot.Cell == null || !slot.Cell.TryUseCharge(comp.EnergyPerUse)) return;
|
if (!comp.Activated || slot.Cell == null || !slot.Cell.TryUseCharge(comp.EnergyPerUse)) return;
|
||||||
|
|||||||
27
Content.Shared/Nutrition/Components/CreamPieComponent.cs
Normal file
27
Content.Shared/Nutrition/Components/CreamPieComponent.cs
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
using Content.Shared.Nutrition.EntitySystems;
|
||||||
|
using Content.Shared.Sound;
|
||||||
|
using Robust.Shared.Analyzers;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.Serialization.Manager.Attributes;
|
||||||
|
using Robust.Shared.ViewVariables;
|
||||||
|
|
||||||
|
namespace Content.Shared.Nutrition.Components
|
||||||
|
{
|
||||||
|
[Friend(typeof(SharedCreamPieSystem))]
|
||||||
|
[RegisterComponent]
|
||||||
|
public class CreamPieComponent : Component
|
||||||
|
{
|
||||||
|
public override string Name => "CreamPie";
|
||||||
|
|
||||||
|
[ViewVariables]
|
||||||
|
[DataField("paralyzeTime")]
|
||||||
|
public float ParalyzeTime { get; } = 1f;
|
||||||
|
|
||||||
|
[ViewVariables]
|
||||||
|
[DataField("sound")]
|
||||||
|
public SoundSpecifier Sound { get; } = new SoundCollectionSpecifier("desecration");
|
||||||
|
|
||||||
|
[ViewVariables]
|
||||||
|
public bool Splatted { get; set; } = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
25
Content.Shared/Nutrition/Components/CreamPiedComponent.cs
Normal file
25
Content.Shared/Nutrition/Components/CreamPiedComponent.cs
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
using System;
|
||||||
|
using Content.Shared.Nutrition.EntitySystems;
|
||||||
|
using Robust.Shared.Analyzers;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.Serialization;
|
||||||
|
using Robust.Shared.ViewVariables;
|
||||||
|
|
||||||
|
namespace Content.Shared.Nutrition.Components
|
||||||
|
{
|
||||||
|
[Friend(typeof(SharedCreamPieSystem))]
|
||||||
|
[RegisterComponent]
|
||||||
|
public class CreamPiedComponent : Component
|
||||||
|
{
|
||||||
|
public override string Name => "CreamPied";
|
||||||
|
|
||||||
|
[ViewVariables]
|
||||||
|
public bool CreamPied { get; set; } = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
[Serializable, NetSerializable]
|
||||||
|
public enum CreamPiedVisuals
|
||||||
|
{
|
||||||
|
Creamed,
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
using System;
|
|
||||||
using Robust.Shared.GameObjects;
|
|
||||||
using Robust.Shared.Serialization;
|
|
||||||
|
|
||||||
namespace Content.Shared.Nutrition.Components
|
|
||||||
{
|
|
||||||
public class SharedCreamPiedComponent : Component
|
|
||||||
{
|
|
||||||
public override string Name => "CreamPied";
|
|
||||||
}
|
|
||||||
|
|
||||||
[Serializable, NetSerializable]
|
|
||||||
public enum CreamPiedVisuals
|
|
||||||
{
|
|
||||||
Creamed,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,75 @@
|
|||||||
|
using Content.Shared.Nutrition.Components;
|
||||||
|
using Content.Shared.Stunnable;
|
||||||
|
using Content.Shared.Throwing;
|
||||||
|
using JetBrains.Annotations;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Shared.Nutrition.EntitySystems
|
||||||
|
{
|
||||||
|
[UsedImplicitly]
|
||||||
|
public abstract class SharedCreamPieSystem : EntitySystem
|
||||||
|
{
|
||||||
|
public override void Initialize()
|
||||||
|
{
|
||||||
|
base.Initialize();
|
||||||
|
|
||||||
|
SubscribeLocalEvent<CreamPieComponent, ThrowDoHitEvent>(OnCreamPieHit);
|
||||||
|
SubscribeLocalEvent<CreamPieComponent, LandEvent>(OnCreamPieLand);
|
||||||
|
SubscribeLocalEvent<CreamPiedComponent, ThrowHitByEvent>(OnCreamPiedHitBy);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SplatCreamPie(EntityUid uid, CreamPieComponent creamPie)
|
||||||
|
{
|
||||||
|
// Already splatted! Do nothing.
|
||||||
|
if (creamPie.Splatted)
|
||||||
|
return;
|
||||||
|
|
||||||
|
creamPie.Splatted = true;
|
||||||
|
|
||||||
|
SplattedCreamPie(uid, creamPie);
|
||||||
|
|
||||||
|
EntityManager.QueueDeleteEntity(uid);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected virtual void SplattedCreamPie(EntityUid uid, CreamPieComponent creamPie) {}
|
||||||
|
|
||||||
|
public void SetCreamPied(EntityUid uid, CreamPiedComponent creamPied, bool value)
|
||||||
|
{
|
||||||
|
if (value == creamPied.CreamPied)
|
||||||
|
return;
|
||||||
|
|
||||||
|
creamPied.CreamPied = value;
|
||||||
|
|
||||||
|
if (ComponentManager.TryGetComponent(uid, out SharedAppearanceComponent? appearance))
|
||||||
|
{
|
||||||
|
appearance.SetData(CreamPiedVisuals.Creamed, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnCreamPieLand(EntityUid uid, CreamPieComponent component, LandEvent args)
|
||||||
|
{
|
||||||
|
SplatCreamPie(uid, component);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnCreamPieHit(EntityUid uid, CreamPieComponent component, ThrowDoHitEvent args)
|
||||||
|
{
|
||||||
|
SplatCreamPie(uid, component);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnCreamPiedHitBy(EntityUid uid, CreamPiedComponent creamPied, ThrowHitByEvent args)
|
||||||
|
{
|
||||||
|
if (args.Thrown.Deleted || !args.Thrown.TryGetComponent(out CreamPieComponent? creamPie)) return;
|
||||||
|
|
||||||
|
SetCreamPied(uid, creamPied, true);
|
||||||
|
|
||||||
|
CreamedEntity(uid, creamPied, args);
|
||||||
|
|
||||||
|
if (ComponentManager.TryGetComponent(uid, out SharedStunnableComponent? stun))
|
||||||
|
{
|
||||||
|
stun.Paralyze(creamPie.ParalyzeTime);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected virtual void CreamedEntity(EntityUid uid, CreamPiedComponent creamPied, ThrowHitByEvent args) {}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,63 +0,0 @@
|
|||||||
using System;
|
|
||||||
using Robust.Shared.Analyzers;
|
|
||||||
using Robust.Shared.GameObjects;
|
|
||||||
|
|
||||||
namespace Content.Shared.Throwing
|
|
||||||
{
|
|
||||||
[RequiresExplicitImplementation]
|
|
||||||
public interface IThrowCollide
|
|
||||||
{
|
|
||||||
void HitBy(ThrowCollideEventArgs eventArgs) {}
|
|
||||||
void DoHit(ThrowCollideEventArgs eventArgs) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
public class ThrowCollideEventArgs : EventArgs
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// The entity that threw <see cref="Thrown"/> and hit <see cref="Target"/>.
|
|
||||||
/// </summary>
|
|
||||||
public IEntity? User { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The entity thrown by <see cref="User"/> that hit <see cref="Target"/>
|
|
||||||
/// </summary>
|
|
||||||
public IEntity Thrown { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The entity hit with <see cref="Thrown"/> by <see cref="User"/>
|
|
||||||
/// </summary>
|
|
||||||
public IEntity Target { get; }
|
|
||||||
|
|
||||||
public ThrowCollideEventArgs(IEntity? user, IEntity thrown, IEntity target)
|
|
||||||
{
|
|
||||||
User = user;
|
|
||||||
Thrown = thrown;
|
|
||||||
Target = target;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public class ThrowCollideEvent : HandledEntityEventArgs
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// The entity that threw <see cref="Thrown"/>.
|
|
||||||
/// </summary>
|
|
||||||
public IEntity? User { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The entity thrown by <see cref="User"/> that hit <see cref="Target"/>
|
|
||||||
/// </summary>
|
|
||||||
public IEntity Thrown { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The entity hit with <see cref="Thrown"/> by <see cref="User"/>
|
|
||||||
/// </summary>
|
|
||||||
public IEntity Target { get; }
|
|
||||||
|
|
||||||
public ThrowCollideEvent(IEntity? user, IEntity thrown, IEntity target)
|
|
||||||
{
|
|
||||||
User = user;
|
|
||||||
Thrown = thrown;
|
|
||||||
Target = target;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
55
Content.Shared/Throwing/ThrowEvents.cs
Normal file
55
Content.Shared/Throwing/ThrowEvents.cs
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
using System;
|
||||||
|
using JetBrains.Annotations;
|
||||||
|
using Robust.Shared.Analyzers;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Shared.Throwing
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Base class for all throw events.
|
||||||
|
/// </summary>
|
||||||
|
public abstract class ThrowEvent : HandledEntityEventArgs
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// The entity that threw <see cref="Thrown"/>.
|
||||||
|
/// </summary>
|
||||||
|
public IEntity? User { get; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The entity thrown by <see cref="User"/> that hit <see cref="Target"/>
|
||||||
|
/// </summary>
|
||||||
|
public IEntity Thrown { get; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The entity hit with <see cref="Thrown"/> by <see cref="User"/>
|
||||||
|
/// </summary>
|
||||||
|
public IEntity Target { get; }
|
||||||
|
|
||||||
|
public ThrowEvent(IEntity? user, IEntity thrown, IEntity target)
|
||||||
|
{
|
||||||
|
User = user;
|
||||||
|
Thrown = thrown;
|
||||||
|
Target = target;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised directed on the target entity being hit by the thrown entity.
|
||||||
|
/// </summary>
|
||||||
|
public class ThrowHitByEvent : ThrowEvent
|
||||||
|
{
|
||||||
|
public ThrowHitByEvent(IEntity? user, IEntity thrown, IEntity target) : base(user, thrown, target)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Raised directed on the thrown entity that hits another.
|
||||||
|
/// </summary>
|
||||||
|
public class ThrowDoHitEvent : ThrowEvent
|
||||||
|
{
|
||||||
|
public ThrowDoHitEvent(IEntity? user, IEntity thrown, IEntity target) : base(user, thrown, target)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -14,8 +14,6 @@ namespace Content.Shared.Throwing
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class ThrownItemSystem : EntitySystem
|
public class ThrownItemSystem : EntitySystem
|
||||||
{
|
{
|
||||||
private List<IThrowCollide> _throwCollide = new();
|
|
||||||
|
|
||||||
private const string ThrowingFixture = "throw-fixture";
|
private const string ThrowingFixture = "throw-fixture";
|
||||||
|
|
||||||
public override void Initialize()
|
public override void Initialize()
|
||||||
@@ -117,46 +115,13 @@ namespace Content.Shared.Throwing
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Calls ThrowCollide on all components that implement the IThrowCollide interface
|
/// Raises collision events on the thrown and target entities.
|
||||||
/// on a thrown entity and the target entity it hit.
|
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void ThrowCollideInteraction(IEntity? user, IPhysBody thrown, IPhysBody target)
|
public void ThrowCollideInteraction(IEntity? user, IPhysBody thrown, IPhysBody target)
|
||||||
{
|
{
|
||||||
// TODO: Just pass in the bodies directly
|
// TODO: Just pass in the bodies directly
|
||||||
var collideMsg = new ThrowCollideEvent(user, thrown.Owner, target.Owner);
|
RaiseLocalEvent(target.Owner.Uid, new ThrowHitByEvent(user, thrown.Owner, target.Owner));
|
||||||
RaiseLocalEvent(target.Owner.Uid, collideMsg);
|
RaiseLocalEvent(thrown.Owner.Uid, new ThrowDoHitEvent(user, thrown.Owner, target.Owner));
|
||||||
if (collideMsg.Handled)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var eventArgs = new ThrowCollideEventArgs(user, thrown.Owner, target.Owner);
|
|
||||||
|
|
||||||
foreach (var comp in target.Owner.GetAllComponents<IThrowCollide>())
|
|
||||||
{
|
|
||||||
_throwCollide.Add(comp);
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (var collide in _throwCollide)
|
|
||||||
{
|
|
||||||
if (target.Owner.Deleted) break;
|
|
||||||
collide.HitBy(eventArgs);
|
|
||||||
}
|
|
||||||
|
|
||||||
_throwCollide.Clear();
|
|
||||||
|
|
||||||
foreach (var comp in thrown.Owner.GetAllComponents<IThrowCollide>())
|
|
||||||
{
|
|
||||||
_throwCollide.Add(comp);
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (var collide in _throwCollide)
|
|
||||||
{
|
|
||||||
if (thrown.Owner.Deleted) break;
|
|
||||||
collide.DoHit(eventArgs);
|
|
||||||
}
|
|
||||||
|
|
||||||
_throwCollide.Clear();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -304,9 +304,11 @@
|
|||||||
- type: CreamPie
|
- type: CreamPie
|
||||||
- type: ThrownItem
|
- type: ThrownItem
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
|
sprite: Objects/Consumable/Food/Baked/pie.rsi
|
||||||
netsync: false
|
netsync: false
|
||||||
sprite: Objects/Consumable/Food/pie.rsi
|
layers:
|
||||||
state: icon
|
- state: tin
|
||||||
|
- state: plain
|
||||||
- type: SolutionContainer
|
- type: SolutionContainer
|
||||||
contents:
|
contents:
|
||||||
reagents:
|
reagents:
|
||||||
|
|||||||
Reference in New Issue
Block a user