Item.h 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. /*
  2. ===========================================================================
  3. Doom 3 BFG Edition GPL Source Code
  4. Copyright (C) 1993-2012 id Software LLC, a ZeniMax Media company.
  5. This file is part of the Doom 3 BFG Edition GPL Source Code ("Doom 3 BFG Edition Source Code").
  6. Doom 3 BFG Edition Source Code is free software: you can redistribute it and/or modify
  7. it under the terms of the GNU General Public License as published by
  8. the Free Software Foundation, either version 3 of the License, or
  9. (at your option) any later version.
  10. Doom 3 BFG Edition Source Code is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. GNU General Public License for more details.
  14. You should have received a copy of the GNU General Public License
  15. along with Doom 3 BFG Edition Source Code. If not, see <http://www.gnu.org/licenses/>.
  16. In addition, the Doom 3 BFG Edition Source Code is also subject to certain additional terms. You should have received a copy of these additional terms immediately following the terms and conditions of the GNU General Public License which accompanied the Doom 3 BFG Edition Source Code. If not, please request a copy in writing from id Software at the address below.
  17. If you have questions concerning this license or the applicable additional terms, you may contact in writing id Software LLC, c/o ZeniMax Media Inc., Suite 120, Rockville, Maryland 20850 USA.
  18. ===========================================================================
  19. */
  20. #ifndef __GAME_ITEM_H__
  21. #define __GAME_ITEM_H__
  22. /*
  23. ===============================================================================
  24. Items the player can pick up or use.
  25. ===============================================================================
  26. */
  27. /*
  28. ================================================
  29. These flags are passed to the Give functions
  30. to set their behavior. We need to be able to
  31. separate the feedback from the actual
  32. state modification so that we can hide lag
  33. on MP clients.
  34. For the previous behavior of functions which
  35. take a giveFlags parameter (this is usually
  36. desired on the server too) pass
  37. ITEM_GIVE_FEEDBACK | ITEM_GIVE_UPDATE_STATE.
  38. ================================================
  39. */
  40. enum itemGiveFlags_t {
  41. ITEM_GIVE_FEEDBACK = BIT( 0 ),
  42. ITEM_GIVE_UPDATE_STATE = BIT( 1 ),
  43. ITEM_GIVE_FROM_WEAPON = BIT( 2 ), // indicates this was given via a weapon's launchPowerup (for bloodstone powerups)
  44. };
  45. class idItem : public idEntity {
  46. public:
  47. CLASS_PROTOTYPE( idItem );
  48. idItem();
  49. virtual ~idItem();
  50. void Save( idSaveGame *savefile ) const;
  51. void Restore( idRestoreGame *savefile );
  52. void Spawn();
  53. void GetAttributes( idDict &attributes ) const;
  54. virtual bool GiveToPlayer( idPlayer *player, unsigned int giveFlags );
  55. virtual bool Pickup( idPlayer *player );
  56. virtual void Think();
  57. virtual void Present();
  58. enum {
  59. EVENT_PICKUP = idEntity::EVENT_MAXEVENTS,
  60. EVENT_RESPAWN,
  61. EVENT_RESPAWNFX,
  62. EVENT_TAKEFLAG,
  63. EVENT_DROPFLAG,
  64. EVENT_FLAGRETURN,
  65. EVENT_FLAGCAPTURE,
  66. EVENT_MAXEVENTS
  67. };
  68. void ClientThink( const int curTime, const float fraction, const bool predict );
  69. virtual void ClientPredictionThink();
  70. virtual bool ClientReceiveEvent( int event, int time, const idBitMsg &msg );
  71. // networking
  72. virtual void WriteToSnapshot( idBitMsg &msg ) const;
  73. virtual void ReadFromSnapshot( const idBitMsg &msg );
  74. protected:
  75. int GetPredictPickupMilliseconds() const { return clientPredictPickupMilliseconds; }
  76. private:
  77. idVec3 orgOrigin;
  78. bool spin;
  79. bool pulse;
  80. bool canPickUp;
  81. // for item pulse effect
  82. int itemShellHandle;
  83. const idMaterial * shellMaterial;
  84. // used to update the item pulse effect
  85. mutable bool inView;
  86. mutable int inViewTime;
  87. mutable int lastCycle;
  88. mutable int lastRenderViewTime;
  89. // used for prediction in mp
  90. int clientPredictPickupMilliseconds;
  91. bool UpdateRenderEntity( renderEntity_s *renderEntity, const renderView_t *renderView ) const;
  92. static bool ModelCallback( renderEntity_s *renderEntity, const renderView_t *renderView );
  93. void Event_DropToFloor();
  94. void Event_Touch( idEntity *other, trace_t *trace );
  95. void Event_Trigger( idEntity *activator );
  96. void Event_Respawn();
  97. void Event_RespawnFx();
  98. };
  99. class idItemPowerup : public idItem {
  100. public:
  101. CLASS_PROTOTYPE( idItemPowerup );
  102. idItemPowerup();
  103. void Save( idSaveGame *savefile ) const;
  104. void Restore( idRestoreGame *savefile );
  105. void Spawn();
  106. virtual bool GiveToPlayer( idPlayer *player, unsigned int giveFlags );
  107. private:
  108. int time;
  109. int type;
  110. };
  111. class idObjective : public idItem {
  112. public:
  113. CLASS_PROTOTYPE( idObjective );
  114. idObjective();
  115. void Save( idSaveGame *savefile ) const;
  116. void Restore( idRestoreGame *savefile );
  117. void Spawn();
  118. private:
  119. idVec3 playerPos;
  120. const idMaterial * screenshot;
  121. void Event_Trigger( idEntity *activator );
  122. void Event_HideObjective( idEntity *e );
  123. void Event_GetPlayerPos();
  124. };
  125. class idVideoCDItem : public idItem {
  126. public:
  127. CLASS_PROTOTYPE( idVideoCDItem );
  128. virtual bool GiveToPlayer( idPlayer *player, unsigned int giveFlags );
  129. };
  130. class idPDAItem : public idItem {
  131. public:
  132. CLASS_PROTOTYPE( idPDAItem );
  133. virtual bool GiveToPlayer( idPlayer *player, unsigned int giveFlags );
  134. };
  135. class idMoveableItem : public idItem {
  136. public:
  137. CLASS_PROTOTYPE( idMoveableItem );
  138. idMoveableItem();
  139. virtual ~idMoveableItem();
  140. void Save( idSaveGame *savefile ) const;
  141. void Restore( idRestoreGame *savefile );
  142. void Spawn();
  143. virtual void Think();
  144. void ClientThink( const int curTime, const float fraction, const bool predict );
  145. virtual bool Collide( const trace_t &collision, const idVec3 &velocity );
  146. virtual bool Pickup( idPlayer *player );
  147. static void DropItems( idAnimatedEntity *ent, const char *type, idList<idEntity *> *list );
  148. static idEntity * DropItem( const char *classname, const idVec3 &origin, const idMat3 &axis, const idVec3 &velocity, int activateDelay, int removeDelay );
  149. virtual void WriteToSnapshot( idBitMsg &msg ) const;
  150. virtual void ReadFromSnapshot( const idBitMsg &msg );
  151. protected:
  152. idPhysics_RigidBody physicsObj;
  153. idClipModel * trigger;
  154. const idDeclParticle * smoke;
  155. int smokeTime;
  156. int nextSoundTime;
  157. bool repeatSmoke; // never stop updating the particles
  158. void Gib( const idVec3 &dir, const char *damageDefName );
  159. void Event_DropToFloor();
  160. void Event_Gib( const char *damageDefName );
  161. };
  162. class idItemTeam : public idMoveableItem {
  163. public:
  164. CLASS_PROTOTYPE( idItemTeam );
  165. idItemTeam();
  166. virtual ~idItemTeam();
  167. void Spawn();
  168. virtual bool Pickup( idPlayer *player );
  169. virtual bool ClientReceiveEvent( int event, int time, const idBitMsg &msg );
  170. virtual void Think(void );
  171. void Drop( bool death = false ); // was the drop caused by death of carrier?
  172. void Return( idPlayer * player = NULL );
  173. void Capture();
  174. virtual void FreeLightDef();
  175. virtual void Present();
  176. // networking
  177. virtual void WriteToSnapshot( idBitMsg &msg ) const;
  178. virtual void ReadFromSnapshot( const idBitMsg &msg );
  179. public:
  180. int team;
  181. // TODO : turn this into a state :
  182. bool carried; // is it beeing carried by a player?
  183. bool dropped; // was it dropped?
  184. private:
  185. idVec3 returnOrigin;
  186. idMat3 returnAxis;
  187. int lastDrop;
  188. const idDeclSkin * skinDefault;
  189. const idDeclSkin * skinCarried;
  190. const function_t * scriptTaken;
  191. const function_t * scriptDropped;
  192. const function_t * scriptReturned;
  193. const function_t * scriptCaptured;
  194. renderLight_t itemGlow; // Used by flags when they are picked up
  195. int itemGlowHandle;
  196. int lastNuggetDrop;
  197. const char * nuggetName;
  198. private:
  199. void Event_TakeFlag( idPlayer * player );
  200. void Event_DropFlag( bool death );
  201. void Event_FlagReturn( idPlayer * player = NULL );
  202. void Event_FlagCapture();
  203. void PrivateReturn();
  204. function_t * LoadScript( char * script );
  205. void SpawnNugget( idVec3 pos );
  206. void UpdateGuis();
  207. };
  208. class idMoveablePDAItem : public idMoveableItem {
  209. public:
  210. CLASS_PROTOTYPE( idMoveablePDAItem );
  211. virtual bool GiveToPlayer( idPlayer *player, unsigned int giveFlags );
  212. };
  213. /*
  214. ===============================================================================
  215. Item removers.
  216. ===============================================================================
  217. */
  218. class idItemRemover : public idEntity {
  219. public:
  220. CLASS_PROTOTYPE( idItemRemover );
  221. void Spawn();
  222. void RemoveItem( idPlayer *player );
  223. private:
  224. void Event_Trigger( idEntity *activator );
  225. };
  226. class idObjectiveComplete : public idItemRemover {
  227. public:
  228. CLASS_PROTOTYPE( idObjectiveComplete );
  229. idObjectiveComplete();
  230. void Save( idSaveGame *savefile ) const;
  231. void Restore( idRestoreGame *savefile );
  232. void Spawn();
  233. private:
  234. idVec3 playerPos;
  235. void Event_Trigger( idEntity *activator );
  236. void Event_HideObjective( idEntity *e );
  237. void Event_GetPlayerPos();
  238. };
  239. #endif /* !__GAME_ITEM_H__ */