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

About this class

This entity class represents inventory items, weapons.

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

OVERVIEW

Represents any item within the players' inventory. These can be used, or be dormant. Some configurations will simply increase your statistics upon touch.

KEYS

  • "targetname" : Name
  • "model" : world model.
  • "model_view" : view model.
  • "model_world" : same as model.
  • "model_player" : (Optional) when equipped, will use this model.
  • "inv_name" : Fancy title. Can be a localized string.
  • "inv_weapon" : name of the weapon to give on pickup. can be the same as this entitydef.
  • "inv_health" : How much health points to give on pick-up.
  • "inv_armor" : How much armor points to give on pick-up.
  • "no_touch" : If 1, will have to be triggered to be given to the activator.
  • "inv_carry" : If 1, will not use the item instantly.
  • "inv_icon" : Material for HUD graphics.
  • "requires" : Name of the item that has to be present in the players inventory in order to be picked up.
  • "frame" : Animation sequence to use when it's a pickup.
  • "hidden_frame" : Animation sequence to use when it was picked up. Will not hide the entity when set.
  • "physics" : This pickup uses physics to interact with the world.
  • "mins" : Collision box mins (e.g. "-16 -16 -16") for the item.
  • "maxs" : Collision box mins (e.g. "16 16 16") for the item.
  • "snd_acquire" : Sound to play when picked up successfully.
  • "snd_respawn" : Sound to play when it respawns.
  • "spin" : Pickup will spin when set.
  • "floating" : Item does not drop to floor.
  • "body" : GoldSrc Body/Geomset to use.
  • "respawn" : Time required for a map-placed version of this item to respawn.

INPUTS

  • "SetRespawnTime" : Sets the time required for a map-placed version of this item to respawn.

EXAMPLES

Some basic items that most games will have some variety off:

HEALTH

entityDef item_health
{
"editor_usage" "Health Item"
"editor_usage2" ""
"editor_usage3" "Gives players 15 Health Points."
"spawnclass" "ncItem"
"model" "models/items/health.vvm"
"mins" "-16 -16 0"
"maxs" "16 16 16"
"inv_health" "15"
}
entityDefAPI_t entityDef
Access entityDefAPI_t functions using this variable.
Definition: api.h:436

In the above example, changing inv_health to inv_armor will increment the armor value instead, as expected.

KEYCARD

entityDef item_keycard
{
"editor_usage" "Lab Keycard Item"
"editor_usage2" ""
"editor_usage3" "Resides in the inventory without much effect on its own."
"spawnclass" "ncItem"
"model" "models/items/keycard.vvm"
"mins" "-16 -16 0"
"maxs" "16 16 16"
"inv_carry" "1"
}

AMMO

entityDef ammo_shells
{
"editor_usage" "Shotgun Shells"
"editor_usage2" ""
"editor_usage3" "Gives players 20 Shells Ammo."
"spawnclass" "ncItem"
"model" "models/ammo/shells.vvm"
"mins" "-16 -16 0"
"maxs" "16 16 16"
"inv_ammo_shells" "20"
}
Inheritance diagram for ncItem:
ncPhysicsEntity ncWeapon

Public Member Functions

void ncItem (void)
 
virtual void Spawned (void)
 Called when the entity is fulled initialized. More...
 
virtual bool ItemPickupCheck (entity)
 
virtual void Touch (entity)
 Called whenever we're touching another entity. More...
 
virtual void Respawn (void)
 Server: Called when the entity first spawns or when game-logic requests the entity to return to its original spawn state. More...
 
virtual void SpawnKey (string, string)
 This method handles entity key/value pairs on map load. More...
 
virtual void Input (entity, string, string)
 Called when we are being prompted by another object/function with an input message. 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...
 
nonvirtual void SetFloating (int)
 
nonvirtual bool GetFloating (void)
 
nonvirtual void SetSpinning (bool)
 
nonvirtual bool GetSpinning (void)
 
nonvirtual void PickupRespawn (void)
 
nonvirtual void SetRespawnTime (float)
 
virtual void OnInventoryUse (void)
 
virtual void OnPickup (void)
 Overridable: Called when this item is picked up. More...
 
virtual void OnUse (entity)
 Overridable: Called when this item is used. More...
 
virtual void PrintDebugInfo (void)
 
nonvirtual void BecomePickup (void)
 Call to turn a weapon into a pickup. More...
 
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 ReceiveEntity (float, float)
 Client: Handles network updates from the server for the associated entity. More...
 
virtual void ReceiveEvent (float)
 
virtual void PredictPreFrame (void)
 
virtual void PredictPostFrame (void)
 
virtual bool IsWeapon (void)
 
virtual bool InInventory (void)
 
virtual void OnRemoveEntity (void)
 Handles what happens before the entity gets removed from the client game. More...
 

Constructor & Destructor Documentation

◆ ncItem()

void ncItem::ncItem ( void  )

Member Function Documentation

◆ AddedToInventory()

void ncItem::AddedToInventory ( void  )
virtual

Called when an item was added to someones inventory.

Reimplemented in ncWeapon.

◆ BecomePickup()

void ncItem::BecomePickup ( void  )

Call to turn a weapon into a pickup.

◆ EvaluateEntity()

void ncItem::EvaluateEntity ( void  )
virtual

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

Reimplemented from ncPhysicsEntity.

Reimplemented in ncWeapon.

◆ GetFloating()

bool ncItem::GetFloating ( void  )

◆ GetSpinning()

bool ncItem::GetSpinning ( void  )

◆ InInventory()

bool ncItem::InInventory ( void  )
virtual

◆ Input()

void ncItem::Input ( entity  eAct,
string  strInput,
string  strData 
)
virtual

Called when we are being prompted by another object/function with an input message.

Reimplemented from ncSurfacePropEntity.

◆ IsWeapon()

bool ncItem::IsWeapon ( void  )
virtual

Reimplemented in ncWeapon.

◆ ItemPickupCheck()

bool ncItem::ItemPickupCheck ( entity  pickerUpper)
virtual

◆ OnInventoryUse()

void ncItem::OnInventoryUse ( void  )
virtual

◆ OnPickup()

void ncItem::OnPickup ( void  )
virtual

Overridable: Called when this item is picked up.

◆ OnRemoveEntity()

void ncItem::OnRemoveEntity ( void  )
virtual

Handles what happens before the entity gets removed from the client game.

Reimplemented from ncIO.

◆ OnUse()

void ncItem::OnUse ( entity  user)
virtual

Overridable: Called when this item is used.

◆ PickupRespawn()

void ncItem::PickupRespawn ( void  )

◆ PredictPostFrame()

void ncItem::PredictPostFrame ( void  )
virtual

Reimplemented in ncWeapon.

◆ PredictPreFrame()

void ncItem::PredictPreFrame ( void  )
virtual

Reimplemented in ncWeapon.

◆ PrintDebugInfo()

void ncItem::PrintDebugInfo ( void  )
virtual

◆ ReceiveEntity()

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

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

Reimplemented from ncPhysicsEntity.

Reimplemented in ncWeapon.

◆ ReceiveEvent()

void ncItem::ReceiveEvent ( float  eventType)
virtual

Reimplemented from ncEntity.

Reimplemented in ncWeapon.

◆ RemovedFromInventory()

void ncItem::RemovedFromInventory ( void  )
virtual

Called when an item was removed from someones inventory.

Reimplemented in ncWeapon.

◆ Respawn()

void ncItem::Respawn ( void  )
virtual

Server: Called when the entity first spawns or when game-logic requests the entity to return to its original spawn state.

Reimplemented from ncPhysicsEntity.

◆ Restore()

void ncItem::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 ncPhysicsEntity.

Reimplemented in ncWeapon.

◆ Save()

void ncItem::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 ncPhysicsEntity.

Reimplemented in ncWeapon.

◆ SendEntity()

float ncItem::SendEntity ( entity  ,
float   
)
virtual

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

Reimplemented from ncPhysicsEntity.

Reimplemented in ncWeapon.

◆ SetFloating()

void ncItem::SetFloating ( int  i)

◆ SetRespawnTime()

void ncItem::SetRespawnTime ( float  newTime)

◆ SetSpinning()

void ncItem::SetSpinning ( bool  value)

◆ Spawned()

void ncItem::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 ncPhysicsEntity.

Reimplemented in ncWeapon.

◆ SpawnKey()

void ncItem::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 ncPhysicsEntity.

Reimplemented in ncWeapon.

◆ Touch()

void ncItem::Touch ( entity  eToucher)
virtual

Called whenever we're touching another entity.

Reimplemented from ncPhysicsEntity.


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