|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404 |
- /*
- * DISTRHO Plugin Framework (DPF)
- * Copyright (C) 2012-2022 Filipe Coelho <falktx@falktx.com>
- *
- * Permission to use, copy, modify, and/or distribute this software for any purpose with
- * or without fee is hereby granted, provided that the above copyright notice and this
- * permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD
- * TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN
- * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
- * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
- * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
- * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
- #ifndef DISTRHO_UI_HPP_INCLUDED
- #define DISTRHO_UI_HPP_INCLUDED
-
- #include "extra/LeakDetector.hpp"
- #include "src/DistrhoPluginChecks.h"
-
- #ifdef DGL_CAIRO
- # include "Cairo.hpp"
- #endif
- #ifdef DGL_OPENGL
- # include "OpenGL.hpp"
- #endif
- #ifdef DGL_VULKAN
- # include "Vulkan.hpp"
- #endif
-
- #if DISTRHO_PLUGIN_HAS_EXTERNAL_UI
- # include "../dgl/Base.hpp"
- # include "extra/ExternalWindow.hpp"
- typedef DISTRHO_NAMESPACE::ExternalWindow UIWidget;
- #elif DISTRHO_UI_USE_CUSTOM
- # include DISTRHO_UI_CUSTOM_INCLUDE_PATH
- typedef DISTRHO_UI_CUSTOM_WIDGET_TYPE UIWidget;
- #elif DISTRHO_UI_USE_CAIRO
- # include "../dgl/Cairo.hpp"
- typedef DGL_NAMESPACE::CairoTopLevelWidget UIWidget;
- #elif DISTRHO_UI_USE_NANOVG
- # include "../dgl/NanoVG.hpp"
- typedef DGL_NAMESPACE::NanoTopLevelWidget UIWidget;
- #else
- # include "../dgl/TopLevelWidget.hpp"
- typedef DGL_NAMESPACE::TopLevelWidget UIWidget;
- #endif
-
- #if DISTRHO_UI_FILE_BROWSER
- # include "extra/FileBrowserDialog.hpp"
- #endif
-
- START_NAMESPACE_DISTRHO
-
- class PluginWindow;
-
- /* ------------------------------------------------------------------------------------------------------------
- * DPF UI */
-
- /**
- @addtogroup MainClasses
- @{
- */
-
- /**
- DPF UI class from where UI instances are created.
-
- @note You must call setSize during construction,
- @TODO Detailed information about this class.
- */
- class UI : public UIWidget
- {
- public:
- /**
- UI class constructor.
- The UI should be initialized to a default state that matches the plugin side.
-
- When @a automaticallyScale is set to true, DPF will automatically scale up the UI
- to fit the host/desktop scale factor.@n
- It assumes aspect ratio is meant to be kept.
- Manually call setGeometryConstraints instead if keeping UI aspect ratio is not required.
- */
- UI(uint width = 0, uint height = 0, bool automaticallyScaleAndSetAsMinimumSize = false);
-
- /**
- Destructor.
- */
- ~UI() override;
-
- /* --------------------------------------------------------------------------------------------------------
- * Host state */
-
- /**
- Check if this UI window is resizable (by the user or window manager).
- There are situations where an UI supports resizing but the plugin host does not, so this could return false.
-
- You might want to add a resize handle for such cases, so the user is still allowed to resize the window.
- (programatically resizing a window is always possible, but the same is not true for the window manager)
- */
- bool isResizable() const noexcept;
-
- /**
- Get the color used for UI background (i.e. window color) in RGBA format.
- Returns 0 by default, in case of error or lack of host support.
-
- The following example code can be use to extract individual colors:
- ```
- const int red = (bgColor >> 24) & 0xff;
- const int green = (bgColor >> 16) & 0xff;
- const int blue = (bgColor >> 8) & 0xff;
- ```
- */
- uint getBackgroundColor() const noexcept;
-
- /**
- Get the color used for UI foreground (i.e. text color) in RGBA format.
- Returns 0xffffffff by default, in case of error or lack of host support.
-
- The following example code can be use to extract individual colors:
- ```
- const int red = (fgColor >> 24) & 0xff;
- const int green = (fgColor >> 16) & 0xff;
- const int blue = (fgColor >> 8) & 0xff;
- ```
- */
- uint getForegroundColor() const noexcept;
-
- /**
- Get the current sample rate used in plugin processing.
- @see sampleRateChanged(double)
- */
- double getSampleRate() const noexcept;
-
- /**
- Get the bundle path where the UI resides.@n
- Can return null if the UI is not available in a bundle (if it is a single binary).
- @see getBinaryFilename
- */
- const char* getBundlePath() const noexcept;
-
- /**
- editParameter.
-
- Touch/pressed-down event.
- Lets the host know the user is tweaking a parameter.
- Required in some hosts to record automation.
- */
- void editParameter(uint32_t index, bool started);
-
- /**
- setParameterValue.
-
- Change a parameter value in the Plugin.
- */
- void setParameterValue(uint32_t index, float value);
-
- #if DISTRHO_PLUGIN_WANT_STATE
- /**
- setState.
- @TODO Document this.
- */
- void setState(const char* key, const char* value);
-
- /**
- Request a new file from the host, matching the properties of a state key.@n
- This will use the native host file browser if available, otherwise a DPF built-in file browser is used.@n
- Response will be sent asynchronously to stateChanged, with the matching key and the new file as the value.@n
- It is not possible to know if the action was cancelled by the user.
-
- @return Success if a file-browser was opened, otherwise false.
- @note You cannot request more than one file at a time.
- */
- bool requestStateFile(const char* key);
- #endif
-
- #if DISTRHO_PLUGIN_WANT_MIDI_INPUT
- /**
- Send a single MIDI note from the UI to the plugin DSP side.@n
- A note with zero velocity will be sent as note-off (MIDI 0x80), otherwise note-on (MIDI 0x90).
- */
- void sendNote(uint8_t channel, uint8_t note, uint8_t velocity);
- #endif
-
- #if DISTRHO_UI_FILE_BROWSER
- /**
- Open a file browser dialog with this window as transient parent.@n
- A few options can be specified to setup the dialog.
-
- If a path is selected, onFileSelected() will be called with the user chosen path.
- If the user cancels or does not pick a file, onFileSelected() will be called with nullptr as filename.
-
- This function does not block the event loop.
-
- @note This is exactly the same API as provided by the Window class,
- but redeclared here so that non-embed/DGL based UIs can still use file browser related functions.
- */
- bool openFileBrowser(const DISTRHO_NAMESPACE::FileBrowserOptions& options = FileBrowserOptions());
- #endif
-
- #if DISTRHO_PLUGIN_WANT_DIRECT_ACCESS
- /* --------------------------------------------------------------------------------------------------------
- * Direct DSP access - DO NOT USE THIS UNLESS STRICTLY NECESSARY!! */
-
- /**
- getPluginInstancePointer.
- @TODO Document this.
- */
- void* getPluginInstancePointer() const noexcept;
- #endif
-
- #if DISTRHO_PLUGIN_HAS_EXTERNAL_UI
- /* --------------------------------------------------------------------------------------------------------
- * External UI helpers */
-
- /**
- Get the bundle path that will be used for the next UI.
- @note: This function is only valid during createUI(),
- it will return null when called from anywhere else.
- */
- static const char* getNextBundlePath() noexcept;
-
- /**
- Get the scale factor that will be used for the next UI.
- @note: This function is only valid during createUI(),
- it will return 1.0 when called from anywhere else.
- */
- static double getNextScaleFactor() noexcept;
-
- # if DISTRHO_PLUGIN_HAS_EMBED_UI
- /**
- Get the Window Id that will be used for the next created window.
- @note: This function is only valid during createUI(),
- it will return 0 when called from anywhere else.
- */
- static uintptr_t getNextWindowId() noexcept;
- # endif
- #endif
-
- protected:
- /* --------------------------------------------------------------------------------------------------------
- * DSP/Plugin Callbacks */
-
- /**
- A parameter has changed on the plugin side.@n
- This is called by the host to inform the UI about parameter changes.
- */
- virtual void parameterChanged(uint32_t index, float value) = 0;
-
- #if DISTRHO_PLUGIN_WANT_PROGRAMS
- /**
- A program has been loaded on the plugin side.@n
- This is called by the host to inform the UI about program changes.
- */
- virtual void programLoaded(uint32_t index) = 0;
- #endif
-
- #if DISTRHO_PLUGIN_WANT_STATE
- /**
- A state has changed on the plugin side.@n
- This is called by the host to inform the UI about state changes.
- */
- virtual void stateChanged(const char* key, const char* value) = 0;
- #endif
-
- /* --------------------------------------------------------------------------------------------------------
- * DSP/Plugin Callbacks (optional) */
-
- /**
- Optional callback to inform the UI about a sample rate change on the plugin side.
- @see getSampleRate()
- */
- virtual void sampleRateChanged(double newSampleRate);
-
- /* --------------------------------------------------------------------------------------------------------
- * UI Callbacks (optional) */
-
- /**
- UI idle function, called to give idle time to the plugin UI directly from the host.
- This is called right after OS event handling and Window idle events (within the same cycle).
- There are no guarantees in terms of timing.
- @see addIdleCallback(IdleCallback*, uint).
- */
- virtual void uiIdle() {}
-
- /**
- Window scale factor function, called when the scale factor changes.
- This function is for plugin UIs to be able to override Window::onScaleFactorChanged(double).
-
- The default implementation does nothing.
- WARNING function needs a proper name
- */
- virtual void uiScaleFactorChanged(double scaleFactor);
-
- #if !DISTRHO_PLUGIN_HAS_EXTERNAL_UI
- /**
- Get the types available for the data in a clipboard.
- Must only be called within the context of uiClipboardDataOffer.
- */
- std::vector<DGL_NAMESPACE::ClipboardDataOffer> getClipboardDataOfferTypes();
-
- /**
- Window clipboard data offer function, called when clipboard has data present, possibly with several datatypes.
- While handling this event, the data types can be investigated with getClipboardDataOfferTypes() to decide whether to accept the offer.
-
- Reimplement and return a non-zero id to accept the clipboard data offer for a particular type.
- UIs must ignore any type they do not recognize.
-
- The default implementation accepts the "text/plain" mimetype.
- */
- virtual uint32_t uiClipboardDataOffer();
-
- /**
- Windows focus function, called when the window gains or loses the keyboard focus.
- This function is for plugin UIs to be able to override Window::onFocus(bool, CrossingMode).
-
- The default implementation does nothing.
- */
- virtual void uiFocus(bool focus, DGL_NAMESPACE::CrossingMode mode);
-
- /**
- Window reshape function, called when the window is resized.
- This function is for plugin UIs to be able to override Window::onReshape(uint, uint).
-
- The plugin UI size will be set right after this function.
- The default implementation sets up the drawing context where necessary.
-
- You should almost never need to override this function.
- The most common exception is custom OpenGL setup, but only really needed for custom OpenGL drawing code.
- */
- virtual void uiReshape(uint width, uint height);
- #endif // !DISTRHO_PLUGIN_HAS_EXTERNAL_UI
-
- #if DISTRHO_UI_FILE_BROWSER
- /**
- Window file selected function, called when a path is selected by the user, as triggered by openFileBrowser().
- This function is for plugin UIs to be able to override Window::onFileSelected(const char*).
-
- This action happens after the user confirms the action, so the file browser dialog will be closed at this point.
- The default implementation does nothing.
-
- If you need to use files as plugin state, please setup and use states with kStateIsFilenamePath instead.
- */
- virtual void uiFileBrowserSelected(const char* filename);
- #endif
-
- /* --------------------------------------------------------------------------------------------------------
- * UI Resize Handling, internal */
-
- #if DISTRHO_PLUGIN_HAS_EXTERNAL_UI
- /**
- External Window resize function, called when the window is resized.
- This is overriden here so the host knows when the UI is resized by you.
- @see ExternalWindow::sizeChanged(uint,uint)
- */
- void sizeChanged(uint width, uint height) override;
- #else
- /**
- Widget resize function, called when the widget is resized.
- This is overriden here so the host knows when the UI is resized by you.
- @see Widget::onResize(const ResizeEvent&)
- */
- void onResize(const ResizeEvent& ev) override;
- #endif
-
- // -------------------------------------------------------------------------------------------------------
-
- private:
- struct PrivateData;
- PrivateData* const uiData;
- friend class PluginWindow;
- friend class UIExporter;
- #if !DISTRHO_PLUGIN_HAS_EXTERNAL_UI
- /** @internal */
- void requestSizeChange(uint width, uint height) override;
- #endif
-
- DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(UI)
- };
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Create UI, entry point */
-
- /**
- @addtogroup EntryPoints
- @{
- */
-
- /**
- createUI.
- @TODO Document this.
- */
- extern UI* createUI();
-
- /** @} */
-
- // -----------------------------------------------------------------------------------------------------------
-
- END_NAMESPACE_DISTRHO
-
- #endif // DISTRHO_UI_HPP_INCLUDED
|