Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

131 lines
7.5 KiB

  1. //========= Copyright Valve Corporation, All rights reserved. ============//
  2. //
  3. // Purpose:
  4. //
  5. // $Workfile: $
  6. // $NoKeywords: $
  7. //===========================================================================//
  8. #if !defined( ITEMPENTS_H )
  9. #define ITEMPENTS_H
  10. #ifdef _WIN32
  11. #pragma once
  12. #endif
  13. #include "ipredictionsystem.h"
  14. #include "shattersurfacetypes.h"
  15. #include "irecipientfilter.h"
  16. class CEffectData;
  17. class KeyValues;
  18. //-----------------------------------------------------------------------------
  19. // Purpose: Shared interface to temp entities
  20. //-----------------------------------------------------------------------------
  21. abstract_class ITempEntsSystem : public IPredictionSystem
  22. {
  23. public:
  24. virtual void ArmorRicochet( IRecipientFilter& filer, float delay,
  25. const Vector* pos, const Vector* dir ) = 0;
  26. virtual void BeamEntPoint( IRecipientFilter& filer, float delay,
  27. int nStartEntity, const Vector *start, int nEndEntity, const Vector* end,
  28. int modelindex, int haloindex, int startframe, int framerate,
  29. float life, float width, float endWidth, int fadeLength, float amplitude,
  30. int r, int g, int b, int a, int speed ) = 0;
  31. virtual void BeamEnts( IRecipientFilter& filer, float delay,
  32. int start, int end, int modelindex, int haloindex, int startframe, int framerate,
  33. float life, float width, float endWidth, int fadeLength, float amplitude,
  34. int r, int g, int b, int a, int speed ) = 0;
  35. virtual void BeamFollow( IRecipientFilter& filter, float delay,
  36. int iEntIndex, int modelIndex, int haloIndex, float life, float width, float endWidth,
  37. float fadeLength, float r, float g, float b, float a ) = 0;
  38. virtual void BeamPoints( IRecipientFilter& filer, float delay,
  39. const Vector* start, const Vector* end, int modelindex, int haloindex, int startframe, int framerate,
  40. float life, float width, float endWidth, int fadeLength, float amplitude,
  41. int r, int g, int b, int a, int speed ) = 0;
  42. virtual void BeamLaser( IRecipientFilter& filer, float delay,
  43. int start, int end, int modelindex, int haloindex, int startframe, int framerate,
  44. float life, float width, float endWidth, int fadeLength, float amplitude, int r, int g, int b, int a, int speed ) = 0;
  45. virtual void BeamRing( IRecipientFilter& filer, float delay,
  46. int start, int end, int modelindex, int haloindex, int startframe, int framerate,
  47. float life, float width, int spread, float amplitude, int r, int g, int b, int a, int speed, int flags = 0 ) = 0;
  48. virtual void BeamRingPoint( IRecipientFilter& filer, float delay,
  49. const Vector& center, float start_radius, float end_radius, int modelindex, int haloindex, int startframe, int framerate,
  50. float life, float width, int spread, float amplitude, int r, int g, int b, int a, int speed, int flags = 0 ) = 0;
  51. virtual void BeamSpline( IRecipientFilter& filer, float delay,
  52. int points, Vector* rgPoints ) = 0;
  53. virtual void BloodStream( IRecipientFilter& filer, float delay,
  54. const Vector* org, const Vector* dir, int r, int g, int b, int a, int amount ) = 0;
  55. virtual void BloodSprite( IRecipientFilter& filer, float delay,
  56. const Vector* org, const Vector *dir, int r, int g, int b, int a, int size ) = 0;
  57. virtual void BreakModel( IRecipientFilter& filer, float delay,
  58. const Vector& pos, const QAngle &angle, const Vector& size, const Vector& vel,
  59. int modelindex, int randomization, int count, float time, int flags ) = 0;
  60. virtual void BSPDecal( IRecipientFilter& filer, float delay,
  61. const Vector* pos, int entity, int index ) = 0;
  62. virtual void ProjectDecal( IRecipientFilter& filter, float delay,
  63. const Vector* pos, const QAngle *angles, float distance, int index ) = 0;
  64. virtual void Bubbles( IRecipientFilter& filer, float delay,
  65. const Vector* mins, const Vector* maxs, float height, int modelindex, int count, float speed ) = 0;
  66. virtual void BubbleTrail( IRecipientFilter& filer, float delay,
  67. const Vector* mins, const Vector* maxs, float height, int modelindex, int count, float speed ) = 0;
  68. virtual void Decal( IRecipientFilter& filer, float delay,
  69. const Vector* pos, const Vector* start, int entity, int hitbox, int index ) = 0;
  70. virtual void DynamicLight( IRecipientFilter& filer, float delay,
  71. const Vector* org, int r, int g, int b, int exponent, float radius, float time, float decay ) = 0;
  72. virtual void Explosion( IRecipientFilter& filer, float delay,
  73. const Vector* pos, int modelindex, float scale, int framerate, int flags, int radius, int magnitude, const Vector* normal = NULL, unsigned char materialType = 'C' ) = 0;
  74. virtual void ShatterSurface( IRecipientFilter& filer, float delay,
  75. const Vector* pos, const QAngle* angle, const Vector* vForce, const Vector* vForcePos,
  76. float width, float height, float shardsize, ShatterSurface_t surfacetype,
  77. int front_r, int front_g, int front_b, int back_r, int back_g, int back_b) = 0;
  78. virtual void GlowSprite( IRecipientFilter& filer, float delay,
  79. const Vector* pos, int modelindex, float life, float size, int brightness ) = 0;
  80. virtual void FootprintDecal( IRecipientFilter& filer, float delay, const Vector *origin, const Vector* right,
  81. int entity, int index, unsigned char materialType ) = 0;
  82. virtual void Fizz( IRecipientFilter& filer, float delay,
  83. const CBaseEntity *ed, int modelindex, int density, int current ) = 0;
  84. virtual void KillPlayerAttachments( IRecipientFilter& filer, float delay,
  85. int player ) = 0;
  86. virtual void LargeFunnel( IRecipientFilter& filer, float delay,
  87. const Vector* pos, int modelindex, int reversed ) = 0;
  88. virtual void MetalSparks( IRecipientFilter& filer, float delay,
  89. const Vector* pos, const Vector* dir ) = 0;
  90. virtual void EnergySplash( IRecipientFilter& filer, float delay,
  91. const Vector* pos, const Vector* dir, bool bExplosive ) = 0;
  92. virtual void PlayerDecal( IRecipientFilter& filer, float delay,
  93. const Vector* pos, int player, int entity ) = 0;
  94. virtual void ShowLine( IRecipientFilter& filer, float delay,
  95. const Vector* start, const Vector* end ) = 0;
  96. virtual void Smoke( IRecipientFilter& filer, float delay,
  97. const Vector* pos, int modelindex, float scale, int framerate ) = 0;
  98. virtual void Sparks( IRecipientFilter& filer, float delay,
  99. const Vector* pos, int nMagnitude, int nTrailLength, const Vector *pDir ) = 0;
  100. virtual void Sprite( IRecipientFilter& filer, float delay,
  101. const Vector* pos, int modelindex, float size, int brightness ) = 0;
  102. virtual void SpriteSpray( IRecipientFilter& filer, float delay,
  103. const Vector* pos, const Vector* dir, int modelindex, int speed, float noise, int count ) = 0;
  104. virtual void WorldDecal( IRecipientFilter& filer, float delay,
  105. const Vector* pos, int index ) = 0;
  106. virtual void MuzzleFlash( IRecipientFilter& filer, float delay,
  107. const Vector &start, const QAngle &angles, float scale, int type ) = 0;
  108. virtual void Dust( IRecipientFilter& filer, float delay,
  109. const Vector &pos, const Vector &dir, float size, float speed ) = 0;
  110. virtual void GaussExplosion( IRecipientFilter& filer, float delay,
  111. const Vector &pos, const Vector &dir, int type ) = 0;
  112. virtual void DispatchEffect( IRecipientFilter& filter, float delay,
  113. const Vector &pos, const char *pName, const CEffectData &data ) = 0;
  114. virtual void PhysicsProp( IRecipientFilter& filter, float delay, int modelindex, int skin,
  115. const Vector& pos, const QAngle &angles, const Vector& vel, int flags, int effects ) = 0;
  116. // For playback from external tools
  117. virtual void TriggerTempEntity( KeyValues *pKeyValues ) = 0;
  118. virtual void ClientProjectile( IRecipientFilter& filter, float delay,
  119. const Vector* vecOrigin, const Vector* vecVelocity, int modelindex, int lifetime, CBaseEntity *pOwner ) = 0;
  120. };
  121. extern ITempEntsSystem *te;
  122. #endif // ITEMPENTS_H