Moveable.h 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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_MOVEABLE_H__
  21. #define __GAME_MOVEABLE_H__
  22. /*
  23. ===============================================================================
  24. Entity using rigid body physics.
  25. ===============================================================================
  26. */
  27. extern const idEventDef EV_BecomeNonSolid;
  28. extern const idEventDef EV_IsAtRest;
  29. class idMoveable : public idEntity {
  30. public:
  31. CLASS_PROTOTYPE( idMoveable );
  32. idMoveable();
  33. ~idMoveable();
  34. void Spawn();
  35. void Save( idSaveGame *savefile ) const;
  36. void Restore( idRestoreGame *savefile );
  37. virtual void Think();
  38. virtual void ClientThink( const int curTime, const float fraction, const bool predict );
  39. virtual void Hide();
  40. virtual void Show();
  41. bool AllowStep() const;
  42. void EnableDamage( bool enable, float duration );
  43. virtual bool Collide( const trace_t &collision, const idVec3 &velocity );
  44. virtual void Killed( idEntity *inflictor, idEntity *attacker, int damage, const idVec3 &dir, int location );
  45. virtual void WriteToSnapshot( idBitMsg &msg ) const;
  46. virtual void ReadFromSnapshot( const idBitMsg &msg );
  47. void SetAttacker( idEntity *ent );
  48. const idEntity * GetAttacker() { return attacker; }
  49. protected:
  50. idPhysics_RigidBody physicsObj; // physics object
  51. idStr brokenModel; // model set when health drops down to or below zero
  52. idStr damage; // if > 0 apply damage to hit entities
  53. idStr monsterDamage;
  54. idEntity *attacker;
  55. idStr fxCollide; // fx system to start when collides with something
  56. int nextCollideFxTime; // next time it is ok to spawn collision fx
  57. float minDamageVelocity; // minimum velocity before moveable applies damage
  58. float maxDamageVelocity; // velocity at which the maximum damage is applied
  59. idCurve_Spline<idVec3> *initialSpline; // initial spline path the moveable follows
  60. idVec3 initialSplineDir; // initial relative direction along the spline path
  61. bool explode; // entity explodes when health drops down to or below zero
  62. bool unbindOnDeath; // unbind from master when health drops down to or below zero
  63. bool allowStep; // allow monsters to step on the object
  64. bool canDamage; // only apply damage when this is set
  65. int nextDamageTime; // next time the movable can hurt the player
  66. int nextSoundTime; // next time the moveable can make a sound
  67. const idMaterial * GetRenderModelMaterial() const;
  68. void BecomeNonSolid();
  69. void InitInitialSpline( int startTime );
  70. bool FollowInitialSplinePath();
  71. void Event_Activate( idEntity *activator );
  72. void Event_BecomeNonSolid();
  73. void Event_SetOwnerFromSpawnArgs();
  74. void Event_IsAtRest();
  75. void Event_EnableDamage( float enable );
  76. };
  77. /*
  78. ===============================================================================
  79. A barrel using rigid body physics. The barrel has special handling of
  80. the view model orientation to make it look like it rolls instead of slides.
  81. ===============================================================================
  82. */
  83. class idBarrel : public idMoveable {
  84. public:
  85. CLASS_PROTOTYPE( idBarrel );
  86. idBarrel();
  87. void Spawn();
  88. void Save( idSaveGame *savefile ) const;
  89. void Restore( idRestoreGame *savefile );
  90. void BarrelThink();
  91. virtual void Think();
  92. virtual bool GetPhysicsToVisualTransform( idVec3 &origin, idMat3 &axis );
  93. virtual void ClientThink( const int curTime, const float fraction, const bool predict );
  94. private:
  95. float radius; // radius of barrel
  96. int barrelAxis; // one of the coordinate axes the barrel cylinder is parallel to
  97. idVec3 lastOrigin; // origin of the barrel the last think frame
  98. idMat3 lastAxis; // axis of the barrel the last think frame
  99. float additionalRotation; // additional rotation of the barrel about it's axis
  100. idMat3 additionalAxis; // additional rotation axis
  101. };
  102. /*
  103. ===============================================================================
  104. A barrel using rigid body physics and special handling of the view model
  105. orientation to make it look like it rolls instead of slides. The barrel
  106. can burn and explode when damaged.
  107. ===============================================================================
  108. */
  109. class idExplodingBarrel : public idBarrel {
  110. public:
  111. CLASS_PROTOTYPE( idExplodingBarrel );
  112. idExplodingBarrel();
  113. ~idExplodingBarrel();
  114. void Spawn();
  115. void Save( idSaveGame *savefile ) const;
  116. void Restore( idRestoreGame *savefile );
  117. bool IsStable();
  118. void SetStability( bool stability );
  119. void StartBurning();
  120. void StopBurning();
  121. virtual void ClientThink( const int curTime, const float fraction, const bool predict );
  122. virtual void Think();
  123. virtual void Damage( idEntity *inflictor, idEntity *attacker, const idVec3 &dir,
  124. const char *damageDefName, const float damageScale, const int location );
  125. virtual void Killed( idEntity *inflictor, idEntity *attacker, int damage, const idVec3 &dir, int location );
  126. virtual void WriteToSnapshot( idBitMsg &msg ) const;
  127. virtual void ReadFromSnapshot( const idBitMsg &msg );
  128. virtual bool ClientReceiveEvent( int event, int time, const idBitMsg &msg );
  129. enum {
  130. EVENT_EXPLODE = idEntity::EVENT_MAXEVENTS,
  131. EVENT_MAXEVENTS
  132. };
  133. private:
  134. typedef enum {
  135. NORMAL = 0,
  136. BURNING,
  137. BURNEXPIRED,
  138. EXPLODING
  139. } explode_state_t;
  140. explode_state_t state;
  141. idVec3 spawnOrigin;
  142. idMat3 spawnAxis;
  143. qhandle_t particleModelDefHandle;
  144. qhandle_t lightDefHandle;
  145. renderEntity_t particleRenderEntity;
  146. renderLight_t light;
  147. int particleTime;
  148. int lightTime;
  149. float time;
  150. bool isStable;
  151. void AddParticles( const char *name, bool burn );
  152. void AddLight( const char *name , bool burn );
  153. void ExplodingEffects();
  154. void UpdateLight();
  155. void Event_Activate( idEntity *activator );
  156. void Event_Respawn();
  157. void Event_Explode();
  158. void Event_TriggerTargets();
  159. };
  160. #endif /* !__GAME_MOVEABLE_H__ */