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.

80 lines
2.6KB

  1. /*
  2. * DISTRHO Plugin Framework (DPF)
  3. * Copyright (C) 2012-2024 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 ExampleUIMeters : public UI
  20. {
  21. public:
  22. ExampleUIMeters()
  23. : UI(600, 400, true)
  24. {
  25. }
  26. protected:
  27. /* --------------------------------------------------------------------------------------------------------
  28. * DSP/Plugin Callbacks */
  29. /**
  30. A parameter has changed on the plugin side.
  31. This is called by the host to inform the UI about parameter changes.
  32. */
  33. void parameterChanged(uint32_t index, float value) override
  34. {
  35. // d_stdout("param changed %u %f", index, value);
  36. char msg[512];
  37. {
  38. const ScopedSafeLocale ssl;
  39. std::snprintf(msg, sizeof(msg) - 1,
  40. "typeof(parameterChanged) === 'function' && parameterChanged(%u, %f)", index, value);
  41. }
  42. evaluateJS(msg);
  43. }
  44. /**
  45. A state has changed on the plugin side.
  46. This is called by the host to inform the UI about state changes.
  47. */
  48. void stateChanged(const char*, const char*) override
  49. {
  50. // nothing here
  51. }
  52. // -------------------------------------------------------------------------------------------------------
  53. private:
  54. /**
  55. Set our UI class as non-copyable and add a leak detector just in case.
  56. */
  57. DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(ExampleUIMeters)
  58. };
  59. /* ------------------------------------------------------------------------------------------------------------
  60. * UI entry point, called by DPF to create a new UI instance. */
  61. UI* createUI()
  62. {
  63. return new ExampleUIMeters();
  64. }
  65. // -----------------------------------------------------------------------------------------------------------
  66. END_NAMESPACE_DISTRHO