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.

62 lines
2.4KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library - "Jules' Utility Class Extensions"
  4. Copyright 2004-11 by Raw Material Software Ltd.
  5. ------------------------------------------------------------------------------
  6. JUCE can be redistributed and/or modified under the terms of the GNU General
  7. Public License (Version 2), as published by the Free Software Foundation.
  8. A copy of the license is included in the JUCE distribution, or can be found
  9. online at www.gnu.org/licenses.
  10. JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
  11. WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  12. A PARTICULAR PURPOSE. See the GNU General Public License for more details.
  13. ------------------------------------------------------------------------------
  14. To release a closed-source product which uses JUCE, commercial licenses are
  15. available: visit www.rawmaterialsoftware.com/juce for more information.
  16. ==============================================================================
  17. */
  18. #ifndef __JUCE_SYSTEMAUDIOVOLUME_JUCEHEADER__
  19. #define __JUCE_SYSTEMAUDIOVOLUME_JUCEHEADER__
  20. //==============================================================================
  21. /**
  22. Contains functions to control the system's master volume.
  23. */
  24. class JUCE_API SystemAudioVolume
  25. {
  26. public:
  27. //==============================================================================
  28. /** Returns the operating system's current volume level in the range 0 to 1.0 */
  29. static float JUCE_CALLTYPE getGain();
  30. /** Attempts to set the operating system's current volume level.
  31. @newGain the level, between 0 and 1.0
  32. @returns true if the operation succeeds
  33. */
  34. static bool JUCE_CALLTYPE setGain (float newGain);
  35. /** Returns true if the system's audio output is currently muted. */
  36. static bool JUCE_CALLTYPE isMuted();
  37. /** Attempts to mute the operating system's audio output.
  38. @shouldBeMuted true if you want it to be muted
  39. @returns true if the operation succeeds
  40. */
  41. static bool JUCE_CALLTYPE setMuted (bool shouldBeMuted);
  42. private:
  43. SystemAudioVolume(); // Don't instantiate this class, just call its static fns.
  44. JUCE_DECLARE_NON_COPYABLE (SystemAudioVolume)
  45. };
  46. #endif // __JUCE_SYSTEMAUDIOVOLUME_JUCEHEADER__