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.

264 lines
13KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2013 - Raw Material Software Ltd.
  5. Permission is granted to use this software under the terms of either:
  6. a) the GPL v2 (or any later version)
  7. b) the Affero GPL v3
  8. Details of these licenses can be found at: www.gnu.org/licenses
  9. JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
  10. WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  11. A PARTICULAR PURPOSE. See the GNU General Public License for more details.
  12. ------------------------------------------------------------------------------
  13. To release a closed-source product which uses JUCE, commercial licenses are
  14. available: visit www.juce.com for more information.
  15. ==============================================================================
  16. */
  17. #ifndef __JUCE_DIALOGWINDOW_JUCEHEADER__
  18. #define __JUCE_DIALOGWINDOW_JUCEHEADER__
  19. #include "juce_DocumentWindow.h"
  20. //==============================================================================
  21. /**
  22. A dialog-box style window.
  23. This class is a convenient way of creating a DocumentWindow with a close button
  24. that can be triggered by pressing the escape key.
  25. Any of the methods available to a DocumentWindow or ResizableWindow are also
  26. available to this, so it can be made resizable, have a menu bar, etc.
  27. You can either override or use an instance of the DialogWindow class directly,
  28. or you can use a DialogWindow::LaunchOptions structure to quickly set up and
  29. launch a box containing a content component.
  30. If you use the class directly, you'll need to override the
  31. DocumentWindow::closeButtonPressed() method to handle the user clicking the close
  32. button - for more info, see the DocumentWindow help.
  33. @see DocumentWindow, ResizableWindow
  34. */
  35. class JUCE_API DialogWindow : public DocumentWindow
  36. {
  37. public:
  38. //==============================================================================
  39. /** Creates a DialogWindow.
  40. @param name the name to give the component - this is also
  41. the title shown at the top of the window. To change
  42. this later, use setName()
  43. @param backgroundColour the colour to use for filling the window's background.
  44. @param escapeKeyTriggersCloseButton if true, then pressing the escape key will cause the
  45. close button to be triggered
  46. @param addToDesktop if true, the window will be automatically added to the
  47. desktop; if false, you can use it as a child component
  48. */
  49. DialogWindow (const String& name,
  50. const Colour& backgroundColour,
  51. bool escapeKeyTriggersCloseButton,
  52. bool addToDesktop = true);
  53. /** Destructor.
  54. If a content component has been set with setContentOwned(), it will be deleted.
  55. */
  56. ~DialogWindow();
  57. //==============================================================================
  58. /** This class defines a collection of settings to be used to open a DialogWindow.
  59. The easiest way to open a DialogWindow is to create yourself a LaunchOptions structure,
  60. initialise its fields with the appropriate details, and then call its launchAsync()
  61. method to launch the dialog.
  62. */
  63. struct LaunchOptions
  64. {
  65. LaunchOptions() noexcept;
  66. /** The title to give the window. */
  67. String dialogTitle;
  68. /** The background colour for the window. */
  69. Colour dialogBackgroundColour;
  70. /** The content component to show in the window. This must not be null!
  71. Using an OptionalScopedPointer to hold this pointer lets you indicate whether
  72. you'd like the dialog to automatically delete the component when the dialog
  73. has terminated.
  74. */
  75. OptionalScopedPointer <Component> content;
  76. /** If this is not a nullptr, it indicates a component that you'd like to position this
  77. dialog box in front of. See the DocumentWindow::centreAroundComponent() method for
  78. more info about this parameter.
  79. */
  80. Component* componentToCentreAround;
  81. /** If true, then the escape key will trigger the dialog's close button. */
  82. bool escapeKeyTriggersCloseButton;
  83. /** If true, the dialog will use a native title bar. See TopLevelWindow::setUsingNativeTitleBar() */
  84. bool useNativeTitleBar;
  85. /** If true, the window will be resizable. See ResizableWindow::setResizable() */
  86. bool resizable;
  87. /** Indicates whether to use a border or corner resizer component. See ResizableWindow::setResizable() */
  88. bool useBottomRightCornerResizer;
  89. /** Launches a new modal dialog window.
  90. This will create a dialog based on the settings in this structure,
  91. launch it modally, and return immediately. The window that is returned
  92. will be automatically deleted when the modal state is terminated.
  93. When the dialog's close button is clicked, it'll automatically terminate its
  94. modal state, but you can also do this programmatically by calling
  95. exitModalState (returnValue) on the DialogWindow.
  96. If your content component needs to find the dialog window that it is
  97. contained in, a quick trick is to do this:
  98. @code
  99. Dialogwindow* dw = contentComponent->findParentComponentOfClass<DialogWindow>();
  100. if (dw != nullptr)
  101. dw->exitModalState (1234);
  102. @endcode
  103. */
  104. DialogWindow* launchAsync();
  105. /** Creates a new DialogWindow instance with these settings.
  106. This method simply creates the window, it doesn't run it modally. In most cases
  107. you'll want to use launchAsync() or runModal() instead.
  108. */
  109. DialogWindow* create();
  110. #if JUCE_MODAL_LOOPS_PERMITTED || DOXYGEN
  111. /** Launches and runs the dialog modally, returning the status code that was
  112. used to terminate the modal loop.
  113. Note that running modal loops inline is a BAD technique. If possible, always
  114. use launchAsync() instead of this method.
  115. */
  116. int runModal();
  117. #endif
  118. };
  119. //==============================================================================
  120. /** Easy way of quickly showing a dialog box containing a given component.
  121. Note: this method has been superceded by the DialogWindow::LaunchOptions structure,
  122. which does the same job with some extra flexibility. The showDialog method is here
  123. for backwards compatibility, but please use DialogWindow::LaunchOptions in new code.
  124. This will open and display a DialogWindow containing a given component, making it
  125. modal, but returning immediately to allow the dialog to finish in its own time. If
  126. you want to block and run a modal loop until the dialog is dismissed, use showModalDialog()
  127. instead.
  128. To close the dialog programmatically, you should call exitModalState (returnValue) on
  129. the DialogWindow that is created. To find a pointer to this window from your
  130. contentComponent, you can do something like this:
  131. @code
  132. Dialogwindow* dw = contentComponent->findParentComponentOfClass<DialogWindow>();
  133. if (dw != nullptr)
  134. dw->exitModalState (1234);
  135. @endcode
  136. @param dialogTitle the dialog box's title
  137. @param contentComponent the content component for the dialog box. Make sure
  138. that this has been set to the size you want it to
  139. be before calling this method. The component won't
  140. be deleted by this call, so you can re-use it or delete
  141. it afterwards
  142. @param componentToCentreAround if this is non-zero, it indicates a component that
  143. you'd like to show this dialog box in front of. See the
  144. DocumentWindow::centreAroundComponent() method for more
  145. info on this parameter
  146. @param backgroundColour a colour to use for the dialog box's background colour
  147. @param escapeKeyTriggersCloseButton if true, then pressing the escape key will cause the
  148. close button to be triggered
  149. @param shouldBeResizable if true, the dialog window has either a resizable border, or
  150. a corner resizer
  151. @param useBottomRightCornerResizer if shouldBeResizable is true, this indicates whether
  152. to use a border or corner resizer component. See ResizableWindow::setResizable()
  153. */
  154. static void showDialog (const String& dialogTitle,
  155. Component* contentComponent,
  156. Component* componentToCentreAround,
  157. const Colour& backgroundColour,
  158. bool escapeKeyTriggersCloseButton,
  159. bool shouldBeResizable = false,
  160. bool useBottomRightCornerResizer = false);
  161. #if JUCE_MODAL_LOOPS_PERMITTED || DOXYGEN
  162. /** Easy way of quickly showing a dialog box containing a given component.
  163. Note: this method has been superceded by the DialogWindow::LaunchOptions structure,
  164. which does the same job with some extra flexibility. The showDialog method is here
  165. for backwards compatibility, but please use DialogWindow::LaunchOptions in new code.
  166. This will open and display a DialogWindow containing a given component, returning
  167. when the user clicks its close button.
  168. It returns the value that was returned by the dialog box's runModalLoop() call.
  169. To close the dialog programmatically, you should call exitModalState (returnValue) on
  170. the DialogWindow that is created. To find a pointer to this window from your
  171. contentComponent, you can do something like this:
  172. @code
  173. Dialogwindow* dw = contentComponent->findParentComponentOfClass<DialogWindow>();
  174. if (dw != nullptr)
  175. dw->exitModalState (1234);
  176. @endcode
  177. @param dialogTitle the dialog box's title
  178. @param contentComponent the content component for the dialog box. Make sure
  179. that this has been set to the size you want it to
  180. be before calling this method. The component won't
  181. be deleted by this call, so you can re-use it or delete
  182. it afterwards
  183. @param componentToCentreAround if this is non-zero, it indicates a component that
  184. you'd like to show this dialog box in front of. See the
  185. DocumentWindow::centreAroundComponent() method for more
  186. info on this parameter
  187. @param backgroundColour a colour to use for the dialog box's background colour
  188. @param escapeKeyTriggersCloseButton if true, then pressing the escape key will cause the
  189. close button to be triggered
  190. @param shouldBeResizable if true, the dialog window has either a resizable border, or
  191. a corner resizer
  192. @param useBottomRightCornerResizer if shouldBeResizable is true, this indicates whether
  193. to use a border or corner resizer component. See ResizableWindow::setResizable()
  194. */
  195. static int showModalDialog (const String& dialogTitle,
  196. Component* contentComponent,
  197. Component* componentToCentreAround,
  198. const Colour& backgroundColour,
  199. bool escapeKeyTriggersCloseButton,
  200. bool shouldBeResizable = false,
  201. bool useBottomRightCornerResizer = false);
  202. #endif
  203. protected:
  204. //==============================================================================
  205. /** @internal */
  206. void resized();
  207. /** @internal */
  208. bool keyPressed (const KeyPress&);
  209. private:
  210. bool escapeKeyTriggersCloseButton;
  211. JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (DialogWindow)
  212. };
  213. #endif // __JUCE_DIALOGWINDOW_JUCEHEADER__