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.

75 lines
2.5KB

  1. /*
  2. * DISTRHO Plugin Framework (DPF)
  3. * Copyright (C) 2012-2019 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)
  24. {
  25. setGeometryConstraints(600, 400, false);
  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. d_stdout("param changed %u %f", index, value);
  37. evaluateJS("if (typeof(parameterChanged) === 'function') { parameterChanged(0, 0); }");
  38. }
  39. /**
  40. A state has changed on the plugin side.
  41. This is called by the host to inform the UI about state changes.
  42. */
  43. void stateChanged(const char*, const char*) override
  44. {
  45. // nothing here
  46. }
  47. // -------------------------------------------------------------------------------------------------------
  48. private:
  49. /**
  50. Set our UI class as non-copyable and add a leak detector just in case.
  51. */
  52. DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(ExampleUIMeters)
  53. };
  54. /* ------------------------------------------------------------------------------------------------------------
  55. * UI entry point, called by DPF to create a new UI instance. */
  56. UI* createUI()
  57. {
  58. return new ExampleUIMeters();
  59. }
  60. // -----------------------------------------------------------------------------------------------------------
  61. END_NAMESPACE_DISTRHO