120 lines
3.7 KiB
C#
120 lines
3.7 KiB
C#
using Content.Shared.Actions.ActionTypes;
|
|
using Content.Shared.Sound;
|
|
using Robust.Shared.GameStates;
|
|
using Robust.Shared.Map;
|
|
|
|
namespace Content.Shared.Weapons.Ranged.Components;
|
|
|
|
[RegisterComponent, NetworkedComponent, Virtual]
|
|
public class GunComponent : Component
|
|
{
|
|
#region Sound
|
|
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("soundGunshot")]
|
|
public SoundSpecifier? SoundGunshot = new SoundPathSpecifier("/Audio/Weapons/Guns/Gunshots/smg.ogg");
|
|
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("soundEmpty")]
|
|
public SoundSpecifier? SoundEmpty = new SoundPathSpecifier("/Audio/Weapons/Guns/Empty/empty.ogg");
|
|
|
|
/// <summary>
|
|
/// Sound played when toggling the <see cref="SelectedMode"/> for this gun.
|
|
/// </summary>
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("soundMode")]
|
|
public SoundSpecifier? SoundModeToggle = new SoundPathSpecifier("/Audio/Weapons/Guns/Misc/selector.ogg");
|
|
|
|
#endregion
|
|
|
|
#region Recoil
|
|
|
|
// These values are very small for now until we get a debug overlay and fine tune it
|
|
|
|
/// <summary>
|
|
/// Last time the gun fired.
|
|
/// Used for recoil purposes.
|
|
/// </summary>
|
|
[ViewVariables, DataField("lastFire")]
|
|
public TimeSpan LastFire = TimeSpan.Zero;
|
|
|
|
/// <summary>
|
|
/// What the current spread is for shooting. This gets changed every time the gun fires.
|
|
/// </summary>
|
|
[ViewVariables, DataField("currentAngle")]
|
|
public Angle CurrentAngle;
|
|
|
|
/// <summary>
|
|
/// How much the spread increases every time the gun fires.
|
|
/// </summary>
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("angleIncrease")]
|
|
public Angle AngleIncrease = Angle.FromDegrees(0.5);
|
|
|
|
/// <summary>
|
|
/// How much the <see cref="CurrentAngle"/> decreases per second.
|
|
/// </summary>
|
|
[ViewVariables, DataField("angleDecay")]
|
|
public Angle AngleDecay = Angle.FromDegrees(4);
|
|
|
|
/// <summary>
|
|
/// The maximum angle allowed for <see cref="CurrentAngle"/>
|
|
/// </summary>
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("maxAngle")]
|
|
public Angle MaxAngle = Angle.FromDegrees(2);
|
|
|
|
/// <summary>
|
|
/// The minimum angle allowed for <see cref="CurrentAngle"/>
|
|
/// </summary>
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("minAngle")]
|
|
public Angle MinAngle = Angle.FromDegrees(1);
|
|
|
|
#endregion
|
|
|
|
/// <summary>
|
|
/// Where the gun is being requested to shoot.
|
|
/// </summary>
|
|
[ViewVariables]
|
|
public EntityCoordinates? ShootCoordinates = null;
|
|
|
|
/// <summary>
|
|
/// Used for tracking semi-auto / burst
|
|
/// </summary>
|
|
[ViewVariables]
|
|
public int ShotCounter = 0;
|
|
|
|
/// <summary>
|
|
/// How many times it shoots per second.
|
|
/// </summary>
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("fireRate")]
|
|
public float FireRate = 8f;
|
|
|
|
/// <summary>
|
|
/// When the gun is next available to be shot.
|
|
/// Can be set multiple times in a single tick due to guns firing faster than a single tick time.
|
|
/// </summary>
|
|
[ViewVariables, DataField("nextFire")]
|
|
public TimeSpan NextFire = TimeSpan.Zero;
|
|
|
|
/// <summary>
|
|
/// What firemodes can be selected.
|
|
/// </summary>
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("availableModes")]
|
|
public SelectiveFire AvailableModes = SelectiveFire.SemiAuto;
|
|
|
|
/// <summary>
|
|
/// What firemode is currently selected.
|
|
/// </summary>
|
|
[ViewVariables(VVAccess.ReadWrite), DataField("selectedMode")]
|
|
public SelectiveFire SelectedMode = SelectiveFire.SemiAuto;
|
|
|
|
[DataField("selectModeAction")]
|
|
public InstantAction? SelectModeAction;
|
|
}
|
|
|
|
[Flags]
|
|
public enum SelectiveFire : byte
|
|
{
|
|
Invalid = 0,
|
|
// Combat mode already functions as the equivalent of Safety
|
|
SemiAuto = 1 << 0,
|
|
Burst = 1 << 1,
|
|
FullAuto = 1 << 2, // Not in the building!
|
|
}
|