DISTRHO Plugin Framework
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.

74 lines
2.4KB

  1. /*
  2. * DISTRHO Plugin Framework (DPF)
  3. * Copyright (C) 2012-2021 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any purpose with
  6. * or without fee is hereby granted, provided that the above copyright notice and this
  7. * permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD
  10. * TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN
  11. * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  12. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
  13. * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  14. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #include "DistrhoUI.hpp"
  17. START_NAMESPACE_DISTRHO
  18. // -----------------------------------------------------------------------------------------------------------
  19. class EmbedExternalExampleUI : public UI
  20. {
  21. public:
  22. EmbedExternalExampleUI()
  23. : UI(405, 256),
  24. fValue(0.0f)
  25. {
  26. }
  27. protected:
  28. /* --------------------------------------------------------------------------------------------------------
  29. * DSP/Plugin Callbacks */
  30. /**
  31. A parameter has changed on the plugin side.
  32. This is called by the host to inform the UI about parameter changes.
  33. */
  34. void parameterChanged(uint32_t index, float value) override
  35. {
  36. if (index != 0)
  37. return;
  38. fValue = value;
  39. }
  40. /* --------------------------------------------------------------------------------------------------------
  41. * External Window overrides */
  42. // -------------------------------------------------------------------------------------------------------
  43. private:
  44. // Current value, cached for when UI becomes visible
  45. float fValue;
  46. /**
  47. Set our UI class as non-copyable and add a leak detector just in case.
  48. */
  49. DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(EmbedExternalExampleUI)
  50. };
  51. /* ------------------------------------------------------------------------------------------------------------
  52. * UI entry point, called by DPF to create a new UI instance. */
  53. UI* createUI()
  54. {
  55. return new EmbedExternalExampleUI();
  56. }
  57. // -----------------------------------------------------------------------------------------------------------
  58. END_NAMESPACE_DISTRHO