The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
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.

70 lines
2.5KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2013 - Raw Material Software Ltd.
  5. Permission is granted to use this software under the terms of either:
  6. a) the GPL v2 (or any later version)
  7. b) the Affero GPL v3
  8. Details of these licenses can be found at: www.gnu.org/licenses
  9. JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
  10. WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  11. A PARTICULAR PURPOSE. See the GNU General Public License for more details.
  12. ------------------------------------------------------------------------------
  13. To release a closed-source product which uses JUCE, commercial licenses are
  14. available: visit www.juce.com for more information.
  15. ==============================================================================
  16. */
  17. #if JUCE_QUICKTIME
  18. //==============================================================================
  19. /**
  20. Uses QuickTime to read the audio track a movie or media file.
  21. As well as QuickTime movies, this should also manage to open other audio
  22. files that quicktime can understand, like mp3, m4a, etc.
  23. @see AudioFormat
  24. */
  25. class JUCE_API QuickTimeAudioFormat : public AudioFormat
  26. {
  27. public:
  28. //==============================================================================
  29. /** Creates a format object. */
  30. QuickTimeAudioFormat();
  31. /** Destructor. */
  32. ~QuickTimeAudioFormat();
  33. //==============================================================================
  34. Array<int> getPossibleSampleRates();
  35. Array<int> getPossibleBitDepths();
  36. bool canDoStereo();
  37. bool canDoMono();
  38. //==============================================================================
  39. AudioFormatReader* createReaderFor (InputStream* sourceStream,
  40. bool deleteStreamIfOpeningFails);
  41. AudioFormatWriter* createWriterFor (OutputStream* streamToWriteTo,
  42. double sampleRateToUse,
  43. unsigned int numberOfChannels,
  44. int bitsPerSample,
  45. const StringPairArray& metadataValues,
  46. int qualityOptionIndex);
  47. private:
  48. JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (QuickTimeAudioFormat)
  49. };
  50. #endif