X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;ds=sidebyside;f=qcsrc%2Fserver%2Ft_items.qh;h=8195d250d023b4e528cb40bfd67d272fde8392c0;hb=78be9d52faa65023bfc76e9cd404db83dadc551e;hp=bb914234e1c26bf8abfe8d385ce718bc1d36f0de;hpb=1ba59bdc6b1e1ad0368f34dbd297e40cc42be243;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/server/t_items.qh b/qcsrc/server/t_items.qh index bb914234e..8195d250d 100644 --- a/qcsrc/server/t_items.qh +++ b/qcsrc/server/t_items.qh @@ -1,48 +1,6 @@ #ifndef T_ITEMS_H #define T_ITEMS_H -// constants -const int IT_UNLIMITED_WEAPON_AMMO = 1; // when this bit is set, using a weapon does not reduce ammo. Checkpoints can give this powerup. -const int IT_UNLIMITED_SUPERWEAPONS = 2; // when this bit is set, superweapons don't expire. Checkpoints can give this powerup. -const int IT_CTF_SHIELDED = 4; // set for the flag shield -const int IT_USING_JETPACK = 8; // confirmation that button is pressed -const int IT_JETPACK = 16; // actual item -const int IT_FUEL_REGEN = 32; // fuel regeneration trigger -// where is 64... ? -const int IT_FUEL = 128; -const int IT_SHELLS = 256; -const int IT_NAILS = 512; -const int IT_ROCKETS = 1024; -const int IT_CELLS = 2048; -const int IT_SUPERWEAPON = 4096; -const int IT_STRENGTH = 8192; -const int IT_INVINCIBLE = 16384; -const int IT_HEALTH = 32768; -const int IT_PLASMA = 65536; - -// shared value space (union): - // for items: - const int IT_KEY1 = 131072; - const int IT_KEY2 = 262144; - // for players: - const int IT_RED_FLAG_TAKEN = 32768; - const int IT_RED_FLAG_LOST = 65536; - const int IT_RED_FLAG_CARRYING = 98304; - const int IT_BLUE_FLAG_TAKEN = 131072; - const int IT_BLUE_FLAG_LOST = 262144; - const int IT_BLUE_FLAG_CARRYING = 393216; -// end - -const int IT_5HP = 524288; -const int IT_25HP = 1048576; -const int IT_ARMOR_SHARD = 2097152; -const int IT_ARMOR = 4194304; - -// item masks -const int IT_AMMO = 3968; // IT_FUEL | IT_SHELLS | IT_NAILS | IT_ROCKETS | IT_CELLS | IT_PLASMA; -const int IT_PICKUPMASK = 51; // IT_FUEL_REGEN | IT_JETPACK | IT_UNLIMITED_AMMO; // strength and invincible are handled separately -const int IT_UNLIMITED_AMMO = 3; // IT_UNLIMITED_SUPERWEAPONS | IT_UNLIMITED_WEAPON_AMMO; - const int AMMO_COUNT = 4; // amount of ammo types to show in the inventory panel // item networking @@ -63,6 +21,13 @@ const int ISF_SIZE = 128; .int ItemStatus; +.float fade_start; +.float fade_end; + +#ifdef SVQC +void StartItemA (entity a); +#endif + #ifdef CSQC float autocvar_cl_animate_items = 1; @@ -76,16 +41,23 @@ string autocvar_cl_simpleitems_postfix = "_simple"; .float spawntime; .float gravity; .vector colormod; -void ItemDraw(); -void ItemDrawSimple(); +void ItemDraw(entity this); +void ItemDrawSimple(entity this); void ItemRead(float _IsNew); #endif #ifdef SVQC +spawnfunc(item_strength); +spawnfunc(item_invincible); +spawnfunc(item_armor_small); +spawnfunc(item_shells); +spawnfunc(item_bullets); +spawnfunc(item_rockets); + float autocvar_sv_simple_items; -float ItemSend(entity to, float sf); +bool ItemSend(entity this, entity to, int sf); float have_pickup_item(void); @@ -126,7 +98,7 @@ void Item_FindTeam(); // Savage: used for item garbage-collection // TODO: perhaps nice special effect? -float ItemSend(entity to, float sf); +bool ItemSend(entity this, entity to, int sf); void ItemUpdate(entity item); // pickup evaluation functions @@ -139,6 +111,7 @@ float weapon_pickupevalfunc(entity player, entity item); float commodity_pickupevalfunc(entity player, entity item); .float is_item; +.entity itemdef; void StartItem (string itemmodel, string pickupsound, float defaultrespawntime, float defaultrespawntimejitter, string itemname, float itemid, float weaponid, float itemflags, float(entity player, entity item) pickupevalfunc, float pickupbasevalue);