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.

51 lines
1.7KB

  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. AudioAppComponent::AudioAppComponent()
  18. {
  19. }
  20. AudioAppComponent::~AudioAppComponent()
  21. {
  22. // If you hit this then your derived class must call shutdown audio in
  23. // destructor!
  24. jassert (audioSourcePlayer.getCurrentSource() == nullptr);
  25. }
  26. void AudioAppComponent::setAudioChannels (int numInputChannels, int numOutputChannels)
  27. {
  28. String audioError = deviceManager.initialise (numInputChannels, numOutputChannels, nullptr, true);
  29. jassert (audioError.isEmpty());
  30. deviceManager.addAudioCallback (&audioSourcePlayer);
  31. audioSourcePlayer.setSource (this);
  32. }
  33. void AudioAppComponent::shutdownAudio()
  34. {
  35. audioSourcePlayer.setSource (nullptr);
  36. deviceManager.removeAudioCallback (&audioSourcePlayer);
  37. deviceManager.closeAudioDevice();
  38. }