make syndie bag and rigs explosion resistant (#22088)
* remove empty file real * support explosion resistance for non-worn things * remove redundant entitystorage resistance * port entitystorage optimisation to apply for everything with 100% resistance * add explosion resistance for bag contents * make thing reusable * add resistance to chest rig too * medical chest rig too --------- Co-authored-by: deltanedas <@deltanedas:kde.org>
This commit is contained in:
@@ -5,7 +5,9 @@ using Robust.Shared.Serialization.TypeSerializers.Implementations.Custom.Prototy
|
|||||||
namespace Content.Server.Explosion.Components;
|
namespace Content.Server.Explosion.Components;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Component that provides entities with explosion resistance.
|
/// Component that provides entities with explosion resistance.
|
||||||
|
/// By default this is applied when worn, but to solely protect the entity itself and
|
||||||
|
/// not the wearer use <c>worn: false</c>.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// This is desirable over just using damage modifier sets, given that equipment like bomb-suits need to
|
/// This is desirable over just using damage modifier sets, given that equipment like bomb-suits need to
|
||||||
@@ -21,6 +23,20 @@ public sealed partial class ExplosionResistanceComponent : Component
|
|||||||
[DataField("damageCoefficient")]
|
[DataField("damageCoefficient")]
|
||||||
public float DamageCoefficient = 1;
|
public float DamageCoefficient = 1;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// When true, resistances will be applied to the entity wearing this item.
|
||||||
|
/// When false, only this entity will get th resistance.
|
||||||
|
/// </summary>
|
||||||
|
[DataField, ViewVariables(VVAccess.ReadWrite)]
|
||||||
|
public bool Worn = true;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Examine string for explosion resistance.
|
||||||
|
/// Passed <c>value</c> from 0 to 100.
|
||||||
|
/// </summary>
|
||||||
|
[DataField, ViewVariables(VVAccess.ReadWrite)]
|
||||||
|
public LocId Examine = "explosion-resistance-coefficient-value";
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Modifiers specific to each explosion type for more customizability.
|
/// Modifiers specific to each explosion type for more customizability.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -389,7 +389,13 @@ public sealed partial class ExplosionSystem
|
|||||||
private void GetEntitiesToDamage(EntityUid uid, DamageSpecifier originalDamage, string prototype)
|
private void GetEntitiesToDamage(EntityUid uid, DamageSpecifier originalDamage, string prototype)
|
||||||
{
|
{
|
||||||
_toDamage.Clear();
|
_toDamage.Clear();
|
||||||
_toDamage.Add((uid, GetDamage(uid, prototype, originalDamage)));
|
|
||||||
|
// don't raise BeforeExplodeEvent if the entity is completely immune to explosions
|
||||||
|
var thisDamage = GetDamage(uid, prototype, originalDamage);
|
||||||
|
if (!thisDamage.Any())
|
||||||
|
return;
|
||||||
|
|
||||||
|
_toDamage.Add((uid, thisDamage));
|
||||||
|
|
||||||
for (var i = 0; i < _toDamage.Count; i++)
|
for (var i = 0; i < _toDamage.Count; i++)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -132,7 +132,8 @@ public sealed partial class ExplosionSystem : EntitySystem
|
|||||||
private void RelayedResistance(EntityUid uid, ExplosionResistanceComponent component,
|
private void RelayedResistance(EntityUid uid, ExplosionResistanceComponent component,
|
||||||
InventoryRelayedEvent<GetExplosionResistanceEvent> args)
|
InventoryRelayedEvent<GetExplosionResistanceEvent> args)
|
||||||
{
|
{
|
||||||
OnGetResistance(uid, component, ref args.Args);
|
if (component.Worn)
|
||||||
|
OnGetResistance(uid, component, ref args.Args);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnGetResistance(EntityUid uid, ExplosionResistanceComponent component, ref GetExplosionResistanceEvent args)
|
private void OnGetResistance(EntityUid uid, ExplosionResistanceComponent component, ref GetExplosionResistanceEvent args)
|
||||||
@@ -378,9 +379,9 @@ public sealed partial class ExplosionSystem : EntitySystem
|
|||||||
|
|
||||||
private void OnArmorExamine(EntityUid uid, ExplosionResistanceComponent component, ref ArmorExamineEvent args)
|
private void OnArmorExamine(EntityUid uid, ExplosionResistanceComponent component, ref ArmorExamineEvent args)
|
||||||
{
|
{
|
||||||
|
var value = MathF.Round((1f - component.DamageCoefficient) * 100, 1);
|
||||||
|
|
||||||
args.Msg.PushNewline();
|
args.Msg.PushNewline();
|
||||||
args.Msg.AddMarkup(Loc.GetString("explosion-resistance-coefficient-value",
|
args.Msg.AddMarkup(Loc.GetString(component.Examine, ("value", value)));
|
||||||
("value", MathF.Round((1f - component.DamageCoefficient) * 100, 1))
|
|
||||||
));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -102,11 +102,7 @@ public sealed class EntityStorageSystem : SharedEntityStorageSystem
|
|||||||
|
|
||||||
private void OnExploded(Entity<EntityStorageComponent> ent, ref BeforeExplodeEvent args)
|
private void OnExploded(Entity<EntityStorageComponent> ent, ref BeforeExplodeEvent args)
|
||||||
{
|
{
|
||||||
if (ent.Comp.ExplosionDamageCoefficient <= 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
args.Contents.AddRange(ent.Comp.Contents.ContainedEntities);
|
args.Contents.AddRange(ent.Comp.Contents.ContainedEntities);
|
||||||
args.DamageCoefficient *= ent.Comp.ExplosionDamageCoefficient;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void TakeGas(EntityUid uid, SharedEntityStorageComponent component)
|
protected override void TakeGas(EntityUid uid, SharedEntityStorageComponent component)
|
||||||
|
|||||||
@@ -124,12 +124,6 @@ public abstract partial class SharedEntityStorageComponent : Component
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
[ViewVariables]
|
[ViewVariables]
|
||||||
public Container Contents = default!;
|
public Container Contents = default!;
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Multiplier for explosion damage that gets applied to contained entities.
|
|
||||||
/// </summary>
|
|
||||||
[DataField]
|
|
||||||
public float ExplosionDamageCoefficient = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[Serializable, NetSerializable]
|
[Serializable, NetSerializable]
|
||||||
|
|||||||
@@ -1 +1,2 @@
|
|||||||
explosion-resistance-coefficient-value = - [color=orange]Explosion[/color] damage reduced by [color=lightblue]{$value}%[/color].
|
explosion-resistance-coefficient-value = - [color=orange]Explosion[/color] damage reduced by [color=lightblue]{$value}%[/color].
|
||||||
|
explosion-resistance-contents-coefficient-value = - [color=orange]Explosion[/color] damage [color=white]to contents[/color] reduced by [color=lightblue]{$value}%[/color].
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
- type: entity
|
- type: entity
|
||||||
parent: Clothing
|
parent: [Clothing, ContentsExplosionResistanceBase]
|
||||||
id: ClothingBackpack
|
id: ClothingBackpack
|
||||||
name: backpack
|
name: backpack
|
||||||
description: You wear this on your back and put items into it.
|
description: You wear this on your back and put items into it.
|
||||||
@@ -28,6 +28,8 @@
|
|||||||
# to prevent bag open/honk spam
|
# to prevent bag open/honk spam
|
||||||
- type: UseDelay
|
- type: UseDelay
|
||||||
delay: 0.5
|
delay: 0.5
|
||||||
|
- type: ExplosionResistance
|
||||||
|
damageCoefficient: 0.9
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: ClothingBackpack
|
parent: ClothingBackpack
|
||||||
|
|||||||
@@ -165,6 +165,8 @@
|
|||||||
components:
|
components:
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Clothing/Back/Duffels/syndicate.rsi
|
sprite: Clothing/Back/Duffels/syndicate.rsi
|
||||||
|
- type: ExplosionResistance
|
||||||
|
damageCoefficient: 0.1
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: ClothingBackpackDuffelSyndicate
|
parent: ClothingBackpackDuffelSyndicate
|
||||||
|
|||||||
@@ -511,7 +511,7 @@
|
|||||||
sprite: Clothing/Belt/salvagewebbing.rsi
|
sprite: Clothing/Belt/salvagewebbing.rsi
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: ClothingBeltStorageBase
|
parent: [ClothingBeltStorageBase, ContentsExplosionResistanceBase]
|
||||||
id: ClothingBeltMilitaryWebbing
|
id: ClothingBeltMilitaryWebbing
|
||||||
name: chest rig
|
name: chest rig
|
||||||
description: A set of tactical webbing worn by Syndicate boarding parties.
|
description: A set of tactical webbing worn by Syndicate boarding parties.
|
||||||
@@ -520,9 +520,11 @@
|
|||||||
sprite: Clothing/Belt/militarywebbing.rsi
|
sprite: Clothing/Belt/militarywebbing.rsi
|
||||||
- type: Clothing
|
- type: Clothing
|
||||||
sprite: Clothing/Belt/militarywebbing.rsi
|
sprite: Clothing/Belt/militarywebbing.rsi
|
||||||
|
- type: ExplosionResistance
|
||||||
|
damageCoefficient: 0.5
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: ClothingBeltStorageBase
|
parent: ClothingBeltMilitaryWebbing
|
||||||
id: ClothingBeltMilitaryWebbingMed
|
id: ClothingBeltMilitaryWebbingMed
|
||||||
name: medical chest rig
|
name: medical chest rig
|
||||||
description: A set of tactical webbing worn by Gorlex Marauder medic operatives.
|
description: A set of tactical webbing worn by Gorlex Marauder medic operatives.
|
||||||
|
|||||||
@@ -29,3 +29,16 @@
|
|||||||
- type: ContainerContainer
|
- type: ContainerContainer
|
||||||
containers:
|
containers:
|
||||||
item: !type:ContainerSlot
|
item: !type:ContainerSlot
|
||||||
|
|
||||||
|
# a piece of clothing that has explosion resistance *for its contents*, not the wearer
|
||||||
|
- type: entity
|
||||||
|
abstract: true
|
||||||
|
id: ContentsExplosionResistanceBase
|
||||||
|
components:
|
||||||
|
- type: ExplosionResistance
|
||||||
|
worn: true # only apply to the clothing itself and items inside, not the wearer
|
||||||
|
examine: explosion-resistance-contents-coefficient-value
|
||||||
|
# to show explosion resistance examine
|
||||||
|
- type: GroupExamine
|
||||||
|
- type: Armor
|
||||||
|
modifiers: {}
|
||||||
|
|||||||
Reference in New Issue
Block a user