sfxTrack.h 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. //-----------------------------------------------------------------------------
  2. // Copyright (c) 2012 GarageGames, LLC
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to
  6. // deal in the Software without restriction, including without limitation the
  7. // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
  8. // sell copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  20. // IN THE SOFTWARE.
  21. //-----------------------------------------------------------------------------
  22. #ifndef _SFXTRACK_H_
  23. #define _SFXTRACK_H_
  24. #ifndef _SIMDATABLOCK_H_
  25. #include "console/simDatablock.h"
  26. #endif
  27. #ifndef _CONSOLETYPES_H_
  28. #include "console/consoleTypes.h"
  29. #endif
  30. class SFXDescription;
  31. /// A datablock that describes sound data for playback.
  32. class SFXTrack : public SimDataBlock
  33. {
  34. public:
  35. typedef SimDataBlock Parent;
  36. enum
  37. {
  38. /// Maximum numbers of parameters that can be pre-assigned to tracks.
  39. MaxNumParameters = 8
  40. };
  41. protected:
  42. /// The description which controls playback settings.
  43. SFXDescription *mDescription;
  44. /// Name of the parameters to which sources playing this track should
  45. /// connect.
  46. StringTableEntry mParameters[ MaxNumParameters ];
  47. /// Overload this to disable direct instantiation of this class via script 'new'.
  48. virtual bool processArguments( S32 argc, ConsoleValueRef *argv );
  49. public:
  50. ///
  51. SFXTrack();
  52. ///
  53. SFXTrack( SFXDescription* description );
  54. /// Returns the description object for this sound profile.
  55. SFXDescription* getDescription() const { return mDescription; }
  56. ///
  57. StringTableEntry getParameter( U32 index ) const
  58. {
  59. AssertFatal( index < MaxNumParameters, "SFXTrack::getParameter() - index out of range" );
  60. return mParameters[ index ];
  61. }
  62. ///
  63. void setParameter( U32 index, const char* name );
  64. // SimDataBlock.
  65. virtual void packData( BitStream* stream );
  66. virtual void unpackData( BitStream* stream );
  67. virtual bool preload( bool server, String& errorStr );
  68. virtual bool onAdd();
  69. virtual void inspectPostApply();
  70. static void initPersistFields();
  71. DECLARE_CONOBJECT( SFXTrack );
  72. DECLARE_CATEGORY( "SFX" );
  73. DECLARE_DESCRIPTION( "Abstract base class for any kind of data that can be turned into SFXSources." );
  74. };
  75. #endif // !_SFXTRACK_H_