Files
tbd-station-14/Content.Shared/Projectiles/ProjectileComponent.cs
SlamBamActionman e58d031300 Hristov & .60 changes - Hristov Rework, Part 2 (#31662)
* Initial commit

* Updated values to reflect new resistances

* Review fixes

* Review fixes

* LINQ BEGONETH
2025-02-04 22:55:09 +01:00

102 lines
3.1 KiB
C#

using Content.Shared.Damage;
using Content.Shared.FixedPoint;
using Robust.Shared.Audio;
using Robust.Shared.GameStates;
using Robust.Shared.Prototypes;
namespace Content.Shared.Projectiles;
[RegisterComponent, NetworkedComponent, AutoGenerateComponentState]
public sealed partial class ProjectileComponent : Component
{
/// <summary>
/// The angle of the fired projectile.
/// </summary>
[DataField, AutoNetworkedField]
public Angle Angle;
/// <summary>
/// The effect that appears when a projectile collides with an entity.
/// </summary>
[DataField, ViewVariables(VVAccess.ReadWrite)]
public EntProtoId? ImpactEffect;
/// <summary>
/// User that shot this projectile.
/// </summary>
[DataField, AutoNetworkedField]
public EntityUid? Shooter;
/// <summary>
/// Weapon used to shoot.
/// </summary>
[DataField, AutoNetworkedField]
public EntityUid? Weapon;
/// <summary>
/// The projectile spawns inside the shooter most of the time, this prevents entities from shooting themselves.
/// </summary>
[DataField, AutoNetworkedField]
public bool IgnoreShooter = true;
/// <summary>
/// The amount of damage the projectile will do.
/// </summary>
[DataField(required: true)] [ViewVariables(VVAccess.ReadWrite)]
public DamageSpecifier Damage = new();
/// <summary>
/// If the projectile should be deleted on collision.
/// </summary>
[DataField]
public bool DeleteOnCollide = true;
/// <summary>
/// Ignore all damage resistances the target has.
/// </summary>
[DataField]
public bool IgnoreResistances = false;
/// <summary>
/// Get that juicy FPS hit sound.
/// </summary>
[DataField]
public SoundSpecifier? SoundHit;
/// <summary>
/// Force the projectiles sound to play rather than potentially playing the entity's sound.
/// </summary>
[DataField]
public bool ForceSound = false;
/// <summary>
/// Whether this projectile will only collide with entities if it was shot from a gun (if <see cref="Weapon"/> is not null).
/// </summary>
[DataField]
public bool OnlyCollideWhenShot = false;
/// <summary>
/// If true, the projectile has hit enough targets and should no longer interact with further collisions pending deletion.
/// </summary>
[DataField]
public bool ProjectileSpent;
/// <summary>
/// When a projectile has this threshold set, it will continue to penetrate entities until the damage dealt reaches this threshold.
/// </summary>
[DataField]
public FixedPoint2 PenetrationThreshold = FixedPoint2.Zero;
/// <summary>
/// If set, the projectile will not penetrate objects that lack the ability to take these damage types.
/// </summary>
[DataField]
public List<string>? PenetrationDamageTypeRequirement;
/// <summary>
/// Tracks the amount of damage dealt for penetration purposes.
/// </summary>
[DataField]
public FixedPoint2 PenetrationAmount = FixedPoint2.Zero;
}