Class used to create a set of options to pass to the show() method. More...
#include <juce_PopupMenu.h>
Public Types | |
enum class | PopupDirection { upwards , downwards } |
Public Member Functions | |
Options () | |
By default, the target screen area will be the current mouse position. | |
Options (const Options &)=default | |
Options & | operator= (const Options &)=default |
Options | withTargetComponent (Component *targetComponent) const |
Sets the target component to use when displaying the menu. | |
Options | withTargetComponent (Component &targetComponent) const |
Options | withTargetScreenArea (Rectangle< int > targetArea) const |
Sets the region of the screen next to which the menu should be displayed. | |
Options | withMousePosition () const |
Sets the target screen area to match the current mouse position. | |
Options | withDeletionCheck (Component &componentToWatchForDeletion) const |
If the passed component has been deleted when the popup menu exits, the selected item's action will not be called. | |
Options | withMinimumWidth (int minWidth) const |
Sets the minimum width of the popup window. | |
Options | withMinimumNumColumns (int minNumColumns) const |
Sets the minimum number of columns in the popup window. | |
Options | withMaximumNumColumns (int maxNumColumns) const |
Sets the maximum number of columns in the popup window. | |
Options | withStandardItemHeight (int standardHeight) const |
Sets the default height of each item in the popup menu. | |
Options | withItemThatMustBeVisible (int idOfItemToBeVisible) const |
Sets an item which must be visible when the menu is initially drawn. | |
Options | withParentComponent (Component *parentComponent) const |
Sets a component that the popup menu will be drawn into. | |
Options | withPreferredPopupDirection (PopupDirection direction) const |
Sets the direction of the popup menu relative to the target screen area. | |
Options | withInitiallySelectedItem (int idOfItemToBeSelected) const |
Sets an item to select in the menu. | |
Options | forSubmenu () const |
Returns a copy of these options with the target component set to null. | |
Component * | getParentComponent () const noexcept |
Gets the parent component. | |
Component * | getTargetComponent () const noexcept |
Gets the target component. | |
Component * | getTopLevelTargetComponent () const noexcept |
Gets the target component that was set for the top-level menu. | |
bool | hasWatchedComponentBeenDeleted () const noexcept |
Returns true if the menu was watching a component, and that component has been deleted, and false otherwise. | |
Rectangle< int > | getTargetScreenArea () const noexcept |
Gets the target screen area. | |
int | getMinimumWidth () const noexcept |
Gets the minimum width. | |
int | getMaximumNumColumns () const noexcept |
Gets the maximum number of columns. | |
int | getMinimumNumColumns () const noexcept |
Gets the minimum number of columns. | |
int | getStandardItemHeight () const noexcept |
Gets the default height of items in the menu. | |
int | getItemThatMustBeVisible () const noexcept |
Gets the ID of the item that must be visible when the menu is initially shown. | |
PopupDirection | getPreferredPopupDirection () const noexcept |
Gets the preferred popup menu direction. | |
int | getInitiallySelectedItemId () const noexcept |
Gets the ID of the item that must be selected when the menu is initially shown. | |
Class used to create a set of options to pass to the show() method.
You can chain together a series of calls to this class's methods to create a set of whatever options you want to specify. E.g.
|
strong |
PopupMenu::Options::Options | ( | ) |
By default, the target screen area will be the current mouse position.
|
default |
Sets the target component to use when displaying the menu.
This is normally the button or other control that triggered the menu.
The target component is primarily used to control the scale of the menu, so it's important to supply a target component if you'll be using your program on hi-DPI displays.
This function will also set the target screen area, so that the menu displays next to the target component. If you need to display the menu at a specific location, you should call withTargetScreenArea() after withTargetComponent.
Sets the region of the screen next to which the menu should be displayed.
To display the menu next to the mouse cursor use withMousePosition(), which is equivalent to passing the following to this function:
withTargetComponent() will also set the target screen area. If you need a target component and a target screen area, make sure to call withTargetScreenArea() after withTargetComponent().
|
nodiscard |
Sets the target screen area to match the current mouse position.
Make sure to call this after withTargetComponent().
|
nodiscard |
If the passed component has been deleted when the popup menu exits, the selected item's action will not be called.
This is useful for avoiding dangling references inside the action callback, in the case that the callback needs to access a component that may be deleted.
|
nodiscard |
Sets the minimum width of the popup window.
|
nodiscard |
Sets the minimum number of columns in the popup window.
|
nodiscard |
Sets the maximum number of columns in the popup window.
|
nodiscard |
Sets the default height of each item in the popup menu.
|
nodiscard |
Sets an item which must be visible when the menu is initially drawn.
This is useful to ensure that a particular item is shown when the menu contains too many items to display on a single screen.
Sets a component that the popup menu will be drawn into.
Some plugin formats, such as AUv3, dislike it when the plugin editor spawns additional windows. Some AUv3 hosts display pink backgrounds underneath transparent popup windows, which is confusing and can appear as though the plugin is malfunctioning. Setting a parent component will avoid this unwanted behaviour, but with the downside that the menu size will be constrained by the size of the parent component.
|
nodiscard |
Sets the direction of the popup menu relative to the target screen area.
|
nodiscard |
Sets an item to select in the menu.
This is useful for controls such as combo boxes, where opening the combo box with the keyboard should ideally highlight the currently-selected item, allowing the next/previous item to be selected by pressing up/down on the keyboard, rather than needing to move the highlighted row down from the top of the menu each time it is opened.
|
nodiscard |
Returns a copy of these options with the target component set to null.
The value of the top-level target component will not be changed.
|
noexcept |
Gets the parent component.
This may be nullptr if the Component has been deleted.
|
noexcept |
Gets the target component.
This may be nullptr if the Component has been deleted.
|
noexcept |
Gets the target component that was set for the top-level menu.
When querying the options of a submenu, getTargetComponent() will always return nullptr, while getTopLevelTargetComponent() will return the target passed to withTargetComponent() when creating the top-level menu.
|
noexcept |
Returns true if the menu was watching a component, and that component has been deleted, and false otherwise.
|
noexcept |
Gets the target screen area.
|
noexcept |
Gets the minimum width.
|
noexcept |
Gets the maximum number of columns.
|
noexcept |
Gets the minimum number of columns.
|
noexcept |
Gets the default height of items in the menu.
|
noexcept |
Gets the ID of the item that must be visible when the menu is initially shown.
|
noexcept |
Gets the preferred popup menu direction.
|
noexcept |
Gets the ID of the item that must be selected when the menu is initially shown.