Nuclide
Software Development Kit for id Technology (BETA)
ncWeapon Class Reference

About this class

This entity class represents weapon based items.

QUAKED ncWeapon (0 0.8 0.8) (-16 -16 0) (16 16 72)

OVERVIEW

This entity class represents weapon based items. It is based on ncItem. The only difference is that the attack related keys get forwarded only to items of this class.

FireInfo

Weapon firing events are split into optional decl titled 'FireInfo' that are queried for implemented attack types.

The "def_fireInfo" key points to the decl containing the primary-attack FireInfo. If that doesn't exist, the keys that would be queried from there are read from the main decl. This goes for any key that is not present in a FireInfo.

The "def_altFireInfo" key points to the decl containing the secondary-attack FireInfo. If that does not exist, secondary attacks are not possible.

KEYS

  • "targetname" : Name
  • "weapon_scriptobject" : mapC progs with the weapon code within.
  • "clipSize" : maximum clip size
  • "mtr_flashShader" : muzzleflash material to Use.
  • "model_flash" : muzzleflash model/sprite to use.
  • "flashColor" : muzzleflash dlight color
  • "flashRadius" : muzzleflash dlight radius
  • "def_dropItem" : when this item is dropped from someones inventory, will spawn this entityDef item instead.
  • "snd_acquire" : pickup noise
  • "snd_respawn" : respawn noise
  • "snd_hum" : idle shader
  • "smoke_muzzle" : smoke particle effect name
  • "continuousSmoke" : whether the particle effect is continous
  • "clipSizeDefault" : CUSTOM: Default clip size on pickup.

FireInfo related keys

  • "def_onFire" : Def to spawn when the weapon is fired.
  • "def_onRelease" : Def to spawn when the weapon has been released.
  • "fireUnderwater" : Default is 1, will set if the weapon can be fired underwater.

Ammo management related keys

  • "ammoType" : name of the ammo type def entry which the weapon uses
  • "ammoRequired" : set to 1 if we require ammo.
  • "ammoPerShot" : Amount of ammo to deduct per successful shot.

Charging/Overcharging

For an overcharge effect, spawn a self-destructive explosion on "def_onFire", and rely on "def_onRelease" for delivering a lethal charge to other enemies.

  • "chargeTime" : Amount of time the weapon has to charge before "def_onFire" is spawned.

Overheating weapons

Overheating of the weapon is done when both keys are set.

  • "overheatLength" : Time in which it takes for the weapon to cool down.
  • "overheatPerShot" : Time added against "overheatLength" when a shot is fired.

Mode switching

  • "altMode" : When 1, then secondary-attack will toggle between "def_fireInfo" and "def_altFireInfo" on primary-attack.

Act overrides

Activities are used to decide which animation gets played and which actions are available for this object. If a model does not define them, you can override them here. This system is SUBJECT to change. It may be removed altogether when FTEQW adds a proper activity override format for existing models.

  • "act_idle" : Sequences to play when idle.
  • "act_idleEmpty" : Sequences to play when idle and with an empty clip.
  • "act_draw" : Sequences to play when drawing the weapon.
  • "act_drawEmpty" : Sequences to play when drawing the empty weapon.
  • "act_holster" : Sequences to play when holstering the weapon.
  • "act_holsterEmpty" : Sequences to play when holstering the empty weapon.
  • "act_fire" : Sequences to play when "def_onFire" fires.
  • "act_fireLast" : Sequences to play when firing the last shot in the weapon.
  • "act_fireEmpty" : Sequences to play when failing to fire the weapon.
  • "act_reload" : Sequences to play when reloading the weapon.
  • "act_reloadEmpty" : Sequences to play when reloading the empty weapon.
  • "act_reloadStart" : When set will play sequences for the start of a shotgun-style reload.
  • "act_reloadEnd" : Like "actReloadStart" but for the end of the shotgun-style reload.
  • "act_delay" : Sequence to play while the weapon is charging (see "chargeTime")
  • "act_loop" : Sequence to play while the weapon is still charging, or in a firing-loop.
  • "act_detonate" : Sequences to play when "detonateOnFire" is triggered.
  • "act_fireFailed" : Sequences to play when the melee attack fails.
  • "act_fireStart" : Sequences to play at the start of a loop/charge attack.
  • "act_fireStop" : Sequences to play at the end of a loop/charge attack.
  • "act_release" : Sequences to play when "def_onRelease" fires.

Misc keys

  • "reloadTime" : Time in seconds between the start/end of a reload.
  • "detonateOnFire" : When set, will detonate all entities of specified classname.
  • "punchAngle" : Weapon punchangle to be applied to the camera when shooting "def_onFire".
  • "fireRate" : Firing rate between shots.
  • "semiAuto" : If not set to "1", the weapon will be fully automatic.
Inheritance diagram for ncWeapon:
ncItem

Public Member Functions

void ncWeapon (void)
 
virtual void InputFrame (void)
 
virtual void AddedToInventory (void)
 Called when an item was added to someones inventory. More...
 
virtual void RemovedFromInventory (void)
 Called when an item was removed from someones inventory. More...
 
virtual void Spawned (void)
 Called when the entity is fulled initialized. More...
 
virtual void SpawnKey (string, string)
 This method handles entity key/value pairs on map load. More...
 
virtual void Save (float)
 Handles saving a copy of this entity to a given filehandle. More...
 
virtual void Restore (string, string)
 Similar to ncIO::SpawnKey() but for save-game fields. More...
 
virtual void EvaluateEntity (void)
 Run each tic after physics are run to determine if we need to send updates over the network. More...
 
virtual float SendEntity (entity, float)
 Called by the engine whenever we need to send a client an update about this entity. More...
 
virtual bool TestFireAbility (string)
 
virtual void UpdateViewmodel (void)
 
virtual void ClientFX (bool)
 
virtual void PredictPreFrame (void)
 
virtual void PredictPostFrame (void)
 
virtual void ReceiveEntity (float, float)
 Client: Handles network updates from the server for the associated entity. More...
 
virtual void ReceiveEvent (float)
 
virtual bool UsesSecondaryAmmo (void)
 
virtual bool IsEmpty (void)
 
virtual bool IsWeapon (void)
 
virtual bool HasReserveAmmo (void)
 
virtual void Draw (void)
 Overridable: Called when we switch to this weapon from another. More...
 
virtual void Holster (void)
 Overridable: Called when we are about to switch to another weapon. More...
 
virtual void PrimaryAttack (void)
 Overridable: On +attack execution. More...
 
virtual void SecondaryAttack (void)
 Overridable: On +attack2 execution. More...
 
virtual void Reload (void)
 Overridable: On +reload execution. More...
 
virtual void Release (void)
 Overridable: When no buttons are held, or you forcefully want to stop firing. More...
 
virtual void Idle (void)
 Overridable: When the weapon is supposed to be doing something on its own. More...
 
virtual void UpdateGUI (void)
 Overridable: When the HUD is requested to be drawn. More...
 
nonvirtual void SetViewModel (string)
 
nonvirtual void SetWorldModel (string)
 
nonvirtual void SetPlayerModel (string)
 
nonvirtual void SetWeaponFrame (float)
 
nonvirtual void PlaySound (string, float, bool)
 
nonvirtual nsweapon_state_t GetWeaponState (void)
 
virtual void SetAttackNext (float)
 
virtual void SetReloadNext (float)
 
virtual void SetIdleNext (float)
 
virtual bool CanFire (void)
 
virtual bool CanIdle (void)
 
virtual bool CanReload (void)
 
virtual bool UseAmmo (string)
 
virtual void WeaponStartedFiring (void)
 Overridable: Called once when the weapon started firing. More...
 
virtual void WeaponStoppedFiring (void)
 Overridable: Called once when the weapon stopped firing. More...
 
nonvirtual bool WeaponIsFiring (void)
 Returns whether the weapon is being actively fired by the owner. More...
 
virtual void FiredWeaponAttack (string)
 Overridable: Controls def_onFire event. More...
 
virtual void ReleasedWeaponAttack (string)
 Overridable: Controls def_onRelease event. More...
 
virtual void SwitchedToWeapon (void)
 Overridable: Called when we've switched to this weapon successfully. More...
 
virtual void SwitchedFromWeapon (void)
 Overridable: Called when we've switched from this weapon successfully. More...
 
virtual void UpdateFireInfoCache (void)
 Overridable: Called when the fireInfo changed. More...
 
nonvirtual void SwitchFireInfo (string)
 Set the active fire Info of the weapon to this one. More...
 
nonvirtual bool DetonateDef (string)
 
nonvirtual void Attack (string)
 

Constructor & Destructor Documentation

◆ ncWeapon()

void ncWeapon::ncWeapon ( void  )

Member Function Documentation

◆ AddedToInventory()

void ncWeapon::AddedToInventory ( void  )
virtual

Called when an item was added to someones inventory.

Reimplemented from ncItem.

◆ Attack()

void ncWeapon::Attack ( string  fireInfo)

◆ CanFire()

bool ncWeapon::CanFire ( void  )
virtual

◆ CanIdle()

bool ncWeapon::CanIdle ( void  )
virtual

◆ CanReload()

bool ncWeapon::CanReload ( void  )
virtual

◆ ClientFX()

void ncWeapon::ClientFX ( bool  isThirdperson)
virtual

◆ DetonateDef()

bool ncWeapon::DetonateDef ( string  defName)

◆ Draw()

void ncWeapon::Draw ( void  )
virtual

Overridable: Called when we switch to this weapon from another.

◆ EvaluateEntity()

void ncWeapon::EvaluateEntity ( void  )
virtual

Run each tic after physics are run to determine if we need to send updates over the network.

Reimplemented from ncItem.

◆ FiredWeaponAttack()

void ncWeapon::FiredWeaponAttack ( string  fireInfo)
virtual

Overridable: Controls def_onFire event.

◆ GetWeaponState()

nsweapon_state_t ncWeapon::GetWeaponState ( void  )

◆ HasReserveAmmo()

bool ncWeapon::HasReserveAmmo ( void  )
virtual

◆ Holster()

void ncWeapon::Holster ( void  )
virtual

Overridable: Called when we are about to switch to another weapon.

◆ Idle()

void ncWeapon::Idle ( void  )
virtual

Overridable: When the weapon is supposed to be doing something on its own.

◆ InputFrame()

void ncWeapon::InputFrame ( void  )
virtual

◆ IsEmpty()

bool ncWeapon::IsEmpty ( void  )
virtual

◆ IsWeapon()

bool ncWeapon::IsWeapon ( void  )
virtual

Reimplemented from ncItem.

◆ PlaySound()

void ncWeapon::PlaySound ( string  soundDef,
float  soundChannel,
bool  clientOnly 
)

◆ PredictPostFrame()

void ncWeapon::PredictPostFrame ( void  )
virtual

Reimplemented from ncItem.

◆ PredictPreFrame()

void ncWeapon::PredictPreFrame ( void  )
virtual

Reimplemented from ncItem.

◆ PrimaryAttack()

void ncWeapon::PrimaryAttack ( void  )
virtual

Overridable: On +attack execution.

◆ ReceiveEntity()

void ncWeapon::ReceiveEntity ( float  flNew,
float  flChanged 
)
virtual

Client: Handles network updates from the server for the associated entity.

Reimplemented from ncItem.

◆ ReceiveEvent()

void ncWeapon::ReceiveEvent ( float  eventID)
virtual

Reimplemented from ncItem.

◆ Release()

void ncWeapon::Release ( void  )
virtual

Overridable: When no buttons are held, or you forcefully want to stop firing.

◆ ReleasedWeaponAttack()

void ncWeapon::ReleasedWeaponAttack ( string  fireInfo)
virtual

Overridable: Controls def_onRelease event.

◆ Reload()

void ncWeapon::Reload ( void  )
virtual

Overridable: On +reload execution.

◆ RemovedFromInventory()

void ncWeapon::RemovedFromInventory ( void  )
virtual

Called when an item was removed from someones inventory.

Reimplemented from ncItem.

◆ Restore()

void ncWeapon::Restore ( string  strKey,
string  strValue 
)
virtual

Similar to ncIO::SpawnKey() but for save-game fields.

Whatever you write into file handles within your ncIO::Save() method needs to be read back in here.

Reimplemented from ncItem.

◆ Save()

void ncWeapon::Save ( float  handle)
virtual

Handles saving a copy of this entity to a given filehandle.

Within you want to use the ncIO::SaveFloat() etc. methods to write the internal member attributes to the specified file handle.

Reimplemented from ncItem.

◆ SecondaryAttack()

void ncWeapon::SecondaryAttack ( void  )
virtual

Overridable: On +attack2 execution.

◆ SendEntity()

float ncWeapon::SendEntity ( entity  ,
float   
)
virtual

Called by the engine whenever we need to send a client an update about this entity.

Reimplemented from ncItem.

◆ SetAttackNext()

void ncWeapon::SetAttackNext ( float  newDelay)
virtual

◆ SetIdleNext()

void ncWeapon::SetIdleNext ( float  newDelay)
virtual

◆ SetPlayerModel()

void ncWeapon::SetPlayerModel ( string  modelPath)

◆ SetReloadNext()

void ncWeapon::SetReloadNext ( float  newDelay)
virtual

◆ SetViewModel()

void ncWeapon::SetViewModel ( string  modelPath)

◆ SetWeaponFrame()

void ncWeapon::SetWeaponFrame ( float  newSequence)

◆ SetWorldModel()

void ncWeapon::SetWorldModel ( string  modelPath)

◆ Spawned()

void ncWeapon::Spawned ( void  )
virtual

Called when the entity is fulled initialized.

Any spawn key/value info pairs have already been dealt with. So now we can make full decisions on the entity. Always make sure to call super::Spawned(); inside your method when overriding.

Reimplemented from ncItem.

◆ SpawnKey()

void ncWeapon::SpawnKey ( string  strKey,
string  strValue 
)
virtual

This method handles entity key/value pairs on map load.

You can easily convert the strValue parameter using the ReadFloat etc. methods that are part of ncIO.

Reimplemented from ncItem.

◆ SwitchedFromWeapon()

void ncWeapon::SwitchedFromWeapon ( void  )
virtual

Overridable: Called when we've switched from this weapon successfully.

◆ SwitchedToWeapon()

void ncWeapon::SwitchedToWeapon ( void  )
virtual

Overridable: Called when we've switched to this weapon successfully.

◆ SwitchFireInfo()

void ncWeapon::SwitchFireInfo ( string  newInfo)

Set the active fire Info of the weapon to this one.

◆ TestFireAbility()

bool ncWeapon::TestFireAbility ( string  fireInfo)
virtual

◆ UpdateFireInfoCache()

void ncWeapon::UpdateFireInfoCache ( void  )
virtual

Overridable: Called when the fireInfo changed.

Cache values here.

◆ UpdateGUI()

void ncWeapon::UpdateGUI ( void  )
virtual

Overridable: When the HUD is requested to be drawn.

◆ UpdateViewmodel()

void ncWeapon::UpdateViewmodel ( void  )
virtual

◆ UseAmmo()

bool ncWeapon::UseAmmo ( string  fireInfo)
virtual

◆ UsesSecondaryAmmo()

bool ncWeapon::UsesSecondaryAmmo ( void  )
virtual

◆ WeaponIsFiring()

bool ncWeapon::WeaponIsFiring ( void  )

Returns whether the weapon is being actively fired by the owner.

◆ WeaponStartedFiring()

void ncWeapon::WeaponStartedFiring ( void  )
virtual

Overridable: Called once when the weapon started firing.

◆ WeaponStoppedFiring()

void ncWeapon::WeaponStoppedFiring ( void  )
virtual

Overridable: Called once when the weapon stopped firing.


The documentation for this class was generated from the following files: