Add EvenHealthChange effect (#37129)
* Add EvenHealthChange effect * cleanup --------- Co-authored-by: slarticodefast <161409025+slarticodefast@users.noreply.github.com>
This commit is contained in:
141
Content.Server/EntityEffects/Effects/EvenHealthChange.cs
Normal file
141
Content.Server/EntityEffects/Effects/EvenHealthChange.cs
Normal file
@@ -0,0 +1,141 @@
|
||||
using Content.Shared.Damage;
|
||||
using Content.Shared.Damage.Prototypes;
|
||||
using Content.Shared.EntityEffects;
|
||||
using Content.Shared.FixedPoint;
|
||||
using Content.Shared.Localizations;
|
||||
using JetBrains.Annotations;
|
||||
using Robust.Shared.Prototypes;
|
||||
using Robust.Shared.Utility;
|
||||
|
||||
namespace Content.Server.EntityEffects.Effects;
|
||||
|
||||
/// <summary>
|
||||
/// Version of <see cref="HealthChange"/> that distributes the healing to groups
|
||||
/// </summary>
|
||||
[UsedImplicitly]
|
||||
public sealed partial class EvenHealthChange : EntityEffect
|
||||
{
|
||||
/// <summary>
|
||||
/// Damage to heal, collected into entire damage groups.
|
||||
/// </summary>
|
||||
[DataField(required: true)]
|
||||
public Dictionary<ProtoId<DamageGroupPrototype>, FixedPoint2> Damage = new();
|
||||
|
||||
/// <summary>
|
||||
/// Should this effect scale the damage by the amount of chemical in the solution?
|
||||
/// Useful for touch reactions, like styptic powder or acid.
|
||||
/// Only usable if the EntityEffectBaseArgs is an EntityEffectReagentArgs.
|
||||
/// </summary>
|
||||
[DataField]
|
||||
public bool ScaleByQuantity;
|
||||
|
||||
/// <summary>
|
||||
/// Should this effect ignore damage modifiers?
|
||||
/// </summary>
|
||||
[DataField]
|
||||
public bool IgnoreResistances = true;
|
||||
|
||||
protected override string ReagentEffectGuidebookText(IPrototypeManager prototype, IEntitySystemManager entSys)
|
||||
{
|
||||
var damages = new List<string>();
|
||||
var heals = false;
|
||||
var deals = false;
|
||||
|
||||
var damagableSystem = entSys.GetEntitySystem<DamageableSystem>();
|
||||
var universalReagentDamageModifier = damagableSystem.UniversalReagentDamageModifier;
|
||||
var universalReagentHealModifier = damagableSystem.UniversalReagentHealModifier;
|
||||
|
||||
foreach (var (group, amount) in Damage)
|
||||
{
|
||||
var groupProto = prototype.Index(group);
|
||||
|
||||
var sign = FixedPoint2.Sign(amount);
|
||||
var mod = 1f;
|
||||
|
||||
if (sign < 0)
|
||||
{
|
||||
heals = true;
|
||||
mod = universalReagentHealModifier;
|
||||
}
|
||||
else if (sign > 0)
|
||||
{
|
||||
deals = true;
|
||||
mod = universalReagentDamageModifier;
|
||||
}
|
||||
|
||||
damages.Add(
|
||||
Loc.GetString("health-change-display",
|
||||
("kind", groupProto.LocalizedName),
|
||||
("amount", MathF.Abs(amount.Float() * mod)),
|
||||
("deltasign", sign)
|
||||
));
|
||||
}
|
||||
|
||||
var healsordeals = heals ? (deals ? "both" : "heals") : (deals ? "deals" : "none");
|
||||
return Loc.GetString("reagent-effect-guidebook-even-health-change",
|
||||
("chance", Probability),
|
||||
("changes", ContentLocalizationManager.FormatList(damages)),
|
||||
("healsordeals", healsordeals));
|
||||
}
|
||||
|
||||
public override void Effect(EntityEffectBaseArgs args)
|
||||
{
|
||||
if (!args.EntityManager.TryGetComponent<DamageableComponent>(args.TargetEntity, out var damageable))
|
||||
return;
|
||||
|
||||
var protoMan = IoCManager.Resolve<IPrototypeManager>();
|
||||
|
||||
var scale = FixedPoint2.New(1);
|
||||
|
||||
if (args is EntityEffectReagentArgs reagentArgs)
|
||||
{
|
||||
scale = ScaleByQuantity ? reagentArgs.Quantity * reagentArgs.Scale : reagentArgs.Scale;
|
||||
}
|
||||
|
||||
var damagableSystem = args.EntityManager.System<DamageableSystem>();
|
||||
var universalReagentDamageModifier = damagableSystem.UniversalReagentDamageModifier;
|
||||
var universalReagentHealModifier = damagableSystem.UniversalReagentHealModifier;
|
||||
|
||||
var dspec = new DamageSpecifier();
|
||||
|
||||
foreach (var (group, amount) in Damage)
|
||||
{
|
||||
var groupProto = protoMan.Index(group);
|
||||
var groupDamage = new Dictionary<string, FixedPoint2>();
|
||||
foreach (var damageId in groupProto.DamageTypes)
|
||||
{
|
||||
var damageAmount = damageable.Damage.DamageDict.GetValueOrDefault(damageId);
|
||||
if (damageAmount != FixedPoint2.Zero)
|
||||
groupDamage.Add(damageId, damageAmount);
|
||||
}
|
||||
|
||||
var sum = groupDamage.Values.Sum();
|
||||
foreach (var (damageId, damageAmount) in groupDamage)
|
||||
{
|
||||
var existing = dspec.DamageDict.GetOrNew(damageId);
|
||||
dspec.DamageDict[damageId] = existing + damageAmount / sum * amount;
|
||||
}
|
||||
}
|
||||
|
||||
if (universalReagentDamageModifier != 1 || universalReagentHealModifier != 1)
|
||||
{
|
||||
foreach (var (type, val) in dspec.DamageDict)
|
||||
{
|
||||
if (val < 0f)
|
||||
{
|
||||
dspec.DamageDict[type] = val * universalReagentHealModifier;
|
||||
}
|
||||
if (val > 0f)
|
||||
{
|
||||
dspec.DamageDict[type] = val * universalReagentDamageModifier;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
damagableSystem.TryChangeDamage(
|
||||
args.TargetEntity,
|
||||
dspec * scale,
|
||||
IgnoreResistances,
|
||||
interruptsDoAfters: false);
|
||||
}
|
||||
}
|
||||
@@ -87,6 +87,21 @@ reagent-effect-guidebook-health-change =
|
||||
}
|
||||
} { $changes }
|
||||
|
||||
reagent-effect-guidebook-even-health-change =
|
||||
{ $chance ->
|
||||
[1] { $healsordeals ->
|
||||
[heals] Evenly heals
|
||||
[deals] Evenly deals
|
||||
*[both] Evenly modifies health by
|
||||
}
|
||||
*[other] { $healsordeals ->
|
||||
[heals] evenly heal
|
||||
[deals] evenly deal
|
||||
*[both] evenly modify health by
|
||||
}
|
||||
} { $changes }
|
||||
|
||||
|
||||
reagent-effect-guidebook-status-effect =
|
||||
{ $type ->
|
||||
[add] { $chance ->
|
||||
|
||||
@@ -822,13 +822,12 @@
|
||||
metabolisms:
|
||||
Medicine:
|
||||
effects:
|
||||
- !type:HealthChange
|
||||
- !type:EvenHealthChange
|
||||
damage:
|
||||
groups:
|
||||
Burn: -2
|
||||
Toxin: -2
|
||||
Airloss: -2
|
||||
Brute: -2
|
||||
Burn: -2
|
||||
Toxin: -2
|
||||
Airloss: -2
|
||||
Brute: -2
|
||||
|
||||
- type: reagent
|
||||
id: Ultravasculine
|
||||
@@ -1205,7 +1204,7 @@
|
||||
conditions:
|
||||
- !type:ReagentThreshold
|
||||
min: 12
|
||||
|
||||
|
||||
- type: reagent
|
||||
id: Opporozidone #Name based of an altered version of the startreck chem "Opporozine"
|
||||
name: reagent-name-opporozidone
|
||||
|
||||
Reference in New Issue
Block a user