- java.lang.Object
- 
- javafx.scene.control.MenuItem
- 
- javafx.scene.control.Menu
 
 
- 
- All Implemented Interfaces:
- Styleable,- EventTarget
 
 @DefaultProperty("items") public class Menu extends MenuItem A popup menu of actionable items which is displayed to the user only upon request. When a menu is visible, in most use cases, the user can select one menu item before the menu goes back to its hidden state. This means the menu is a good place to put important functionality that does not necessarily need to be visible at all times to the user. Menus are typically placed in a MenuBar, or as a submenu of another Menu. If the intention is to offer a context menu when the user right-clicks in a certain area of their user interface, then this is the wrong control to use. This is because when Menu is added to the scenegraph, it has a visual representation that will result in it appearing on screen. Instead,ContextMenushould be used in this circumstance.Creating a Menu and inserting it into a MenuBar is easy, as shown below: Menu menu1 = new Menu("File"); MenuBar menuBar = new MenuBar(menu1);A Menu is a subclass of MenuItemwhich means that it can be inserted into a Menu'sitemsObservableList, resulting in a submenu being created:MenuItem menu12 = new MenuItem("Open"); menu1.getItems().add(menu12);  The items ObservableList allows for any MenuItemtype to be inserted, including its subclassesMenu,MenuItem,RadioMenuItem,CheckMenuItem,CustomMenuItemandSeparatorMenuItem. In order to insert an arbitraryNodeto a Menu, a CustomMenuItem can be used. One exception to this general rule is thatSeparatorMenuItemcould be used for inserting a separator.
- 
- 
Property SummaryProperties Type Property Description ObjectProperty<EventHandler<Event>>onHiddenCalled just after theContextMenuhas been hidden.ObjectProperty<EventHandler<Event>>onHidingCalled just prior to theContextMenubeing hidden.ObjectProperty<EventHandler<Event>>onShowingCalled just prior to theContextMenubeing shown, even if the menu has no items to show.ObjectProperty<EventHandler<Event>>onShownCalled just after theContextMenuis shown.ReadOnlyBooleanPropertyshowingIndicates whether theContextMenuis currently visible.- 
Properties inherited from class javafx.scene.control.MenuItemaccelerator, disable, graphic, id, mnemonicParsing, onAction, onMenuValidation, parentMenu, parentPopup, style, text, visible
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static EventType<Event>ON_HIDDENCalled when the contextMenu for this menu is hidden.static EventType<Event>ON_HIDINGCalled when the contextMenu for this menu will be hidden.static EventType<Event>ON_SHOWINGCalled when the contextMenu for this menu will be shown.static EventType<Event>ON_SHOWNCalled when the contextMenu for this menu shows.- 
Fields inherited from class javafx.scene.control.MenuItemMENU_VALIDATION_EVENT
 
- 
 - 
Constructor SummaryConstructors Constructor Description Menu()Constructs a Menu with an empty string for its display text.Menu(String text)Constructs a Menu and sets the display text with the specified text.Menu(String text, Node graphic)Constructs a Menu and sets the display text with the specified text and sets the graphicNodeto the given node.Menu(String text, Node graphic, MenuItem... items)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description <E extends Event>
 voidaddEventHandler(EventType<E> eventType, EventHandler<E> eventHandler)Registers an event handler to this MenuItem.EventDispatchChainbuildEventDispatchChain(EventDispatchChain tail)Construct an event dispatch chain for this target.ObservableList<MenuItem>getItems()The items to show within this menu.EventHandler<Event>getOnHidden()Gets the value of the property onHidden.EventHandler<Event>getOnHiding()Gets the value of the property onHiding.EventHandler<Event>getOnShowing()Gets the value of the property onShowing.EventHandler<Event>getOnShown()Gets the value of the property onShown.voidhide()Hides theContextMenuif it was previously showing, and any showing submenus.booleanisShowing()Gets the value of the property showing.ObjectProperty<EventHandler<Event>>onHiddenProperty()Called just after theContextMenuhas been hidden.ObjectProperty<EventHandler<Event>>onHidingProperty()Called just prior to theContextMenubeing hidden.ObjectProperty<EventHandler<Event>>onShowingProperty()Called just prior to theContextMenubeing shown, even if the menu has no items to show.ObjectProperty<EventHandler<Event>>onShownProperty()Called just after theContextMenuis shown.<E extends Event>
 voidremoveEventHandler(EventType<E> eventType, EventHandler<E> eventHandler)Unregisters a previously registered event handler from this MenuItem.voidsetOnHidden(EventHandler<Event> value)Sets the value of the property onHidden.voidsetOnHiding(EventHandler<Event> value)Sets the value of the property onHiding.voidsetOnShowing(EventHandler<Event> value)Sets the value of the property onShowing.voidsetOnShown(EventHandler<Event> value)Sets the value of the property onShown.voidshow()If the Menu is not disabled and theContextMenuis not already showing, then this will cause theContextMenuto be shown.ReadOnlyBooleanPropertyshowingProperty()Indicates whether theContextMenuis currently visible.- 
Methods inherited from class javafx.scene.control.MenuItemacceleratorProperty, disableProperty, fire, getAccelerator, getCssMetaData, getGraphic, getId, getOnAction, getOnMenuValidation, getParentMenu, getParentPopup, getProperties, getPseudoClassStates, getStyle, getStyleableNode, getStyleableParent, getStyleClass, getText, getTypeSelector, getUserData, graphicProperty, idProperty, isDisable, isMnemonicParsing, isVisible, mnemonicParsingProperty, onActionProperty, onMenuValidationProperty, parentMenuProperty, parentPopupProperty, setAccelerator, setDisable, setGraphic, setId, setMnemonicParsing, setOnAction, setOnMenuValidation, setParentMenu, setParentPopup, setStyle, setText, setUserData, setVisible, styleProperty, textProperty, toString, visibleProperty
 
- 
 
- 
- 
- 
Property Detail- 
showingpublic final ReadOnlyBooleanProperty showingProperty Indicates whether theContextMenuis currently visible.- Default value:
- false
- See Also:
- isShowing()
 
 - 
onShowingpublic final ObjectProperty<EventHandler<Event>> onShowingProperty Called just prior to theContextMenubeing shown, even if the menu has no items to show. Note however that this won't be called if the menu does not have a valid anchor node.- See Also:
- getOnShowing(),- setOnShowing(EventHandler)
 
 - 
onShownpublic final ObjectProperty<EventHandler<Event>> onShownProperty Called just after theContextMenuis shown.- See Also:
- getOnShown(),- setOnShown(EventHandler)
 
 - 
onHidingpublic final ObjectProperty<EventHandler<Event>> onHidingProperty Called just prior to theContextMenubeing hidden.- See Also:
- getOnHiding(),- setOnHiding(EventHandler)
 
 - 
onHiddenpublic final ObjectProperty<EventHandler<Event>> onHiddenProperty Called just after theContextMenuhas been hidden.- See Also:
- getOnHidden(),- setOnHidden(EventHandler)
 
 
- 
 - 
Field Detail- 
ON_SHOWINGpublic static final EventType<Event> ON_SHOWING Called when the contextMenu for this menu will be shown. However if the contextMenu is empty then this will not be called. 
 - 
ON_SHOWNpublic static final EventType<Event> ON_SHOWN Called when the contextMenu for this menu shows. However if the contextMenu is empty then this will not be called. 
 - 
ON_HIDINGpublic static final EventType<Event> ON_HIDING Called when the contextMenu for this menu will be hidden. However if the contextMenu is empty then this will not be called. 
 
- 
 - 
Constructor Detail- 
Menupublic Menu() Constructs a Menu with an empty string for its display text.- Since:
- JavaFX 2.2
 
 - 
Menupublic Menu(String text) Constructs a Menu and sets the display text with the specified text.- Parameters:
- text- the text to display on the menu button
 
 - 
Menupublic Menu(String text, Node graphic) Constructs a Menu and sets the display text with the specified text and sets the graphicNodeto the given node.- Parameters:
- text- the text to display on the menu button
- graphic- the graphic to display on the menu button
 
 - 
Menupublic Menu(String text, Node graphic, MenuItem... items) Constructs a Menu and sets the display text with the specified text, the graphicNodeto the given node, and inserts the given items into theitemslist.- Parameters:
- text- the text to display on the menu button
- graphic- the graphic to display on the menu button
- items- The items to display in the popup menu.
- Since:
- JavaFX 8u40
 
 
- 
 - 
Method Detail- 
isShowingpublic final boolean isShowing() Gets the value of the property showing.- Property description:
- Indicates whether the ContextMenuis currently visible.
- Default value:
- false
 
 - 
showingPropertypublic final ReadOnlyBooleanProperty showingProperty() Indicates whether theContextMenuis currently visible.- Default value:
- false
- See Also:
- isShowing()
 
 - 
onShowingPropertypublic final ObjectProperty<EventHandler<Event>> onShowingProperty() Called just prior to theContextMenubeing shown, even if the menu has no items to show. Note however that this won't be called if the menu does not have a valid anchor node.- See Also:
- getOnShowing(),- setOnShowing(EventHandler)
 
 - 
setOnShowingpublic final void setOnShowing(EventHandler<Event> value) Sets the value of the property onShowing.- Property description:
- Called just prior to the ContextMenubeing shown, even if the menu has no items to show. Note however that this won't be called if the menu does not have a valid anchor node.
 
 - 
getOnShowingpublic final EventHandler<Event> getOnShowing() Gets the value of the property onShowing.- Property description:
- Called just prior to the ContextMenubeing shown, even if the menu has no items to show. Note however that this won't be called if the menu does not have a valid anchor node.
 
 - 
onShownPropertypublic final ObjectProperty<EventHandler<Event>> onShownProperty() Called just after theContextMenuis shown.- See Also:
- getOnShown(),- setOnShown(EventHandler)
 
 - 
setOnShownpublic final void setOnShown(EventHandler<Event> value) Sets the value of the property onShown.- Property description:
- Called just after the ContextMenuis shown.
 
 - 
getOnShownpublic final EventHandler<Event> getOnShown() Gets the value of the property onShown.- Property description:
- Called just after the ContextMenuis shown.
 
 - 
onHidingPropertypublic final ObjectProperty<EventHandler<Event>> onHidingProperty() Called just prior to theContextMenubeing hidden.- See Also:
- getOnHiding(),- setOnHiding(EventHandler)
 
 - 
setOnHidingpublic final void setOnHiding(EventHandler<Event> value) Sets the value of the property onHiding.- Property description:
- Called just prior to the ContextMenubeing hidden.
 
 - 
getOnHidingpublic final EventHandler<Event> getOnHiding() Gets the value of the property onHiding.- Property description:
- Called just prior to the ContextMenubeing hidden.
 
 - 
onHiddenPropertypublic final ObjectProperty<EventHandler<Event>> onHiddenProperty() Called just after theContextMenuhas been hidden.- See Also:
- getOnHidden(),- setOnHidden(EventHandler)
 
 - 
setOnHiddenpublic final void setOnHidden(EventHandler<Event> value) Sets the value of the property onHidden.- Property description:
- Called just after the ContextMenuhas been hidden.
 
 - 
getOnHiddenpublic final EventHandler<Event> getOnHidden() Gets the value of the property onHidden.- Property description:
- Called just after the ContextMenuhas been hidden.
 
 - 
getItemspublic final ObservableList<MenuItem> getItems() The items to show within this menu. If this ObservableList is modified at runtime, the Menu will update as expected.- Returns:
- the list of items
 
 - 
showpublic void show() If the Menu is not disabled and theContextMenuis not already showing, then this will cause theContextMenuto be shown.
 - 
hidepublic void hide() Hides theContextMenuif it was previously showing, and any showing submenus. If this menu is not showing, then invoking this function has no effect.
 - 
addEventHandlerpublic <E extends Event> void addEventHandler(EventType<E> eventType, EventHandler<E> eventHandler) Registers an event handler to this MenuItem. The handler is called when the menu item receives anEventof the specified type during the bubbling phase of event delivery.- Overrides:
- addEventHandlerin class- MenuItem
- Type Parameters:
- E- the specific event class of the handler
- Parameters:
- eventType- the type of the events to receive by the handler
- eventHandler- the handler to register
 
 - 
removeEventHandlerpublic <E extends Event> void removeEventHandler(EventType<E> eventType, EventHandler<E> eventHandler) Unregisters a previously registered event handler from this MenuItem. One handler might have been registered for different event types, so the caller needs to specify the particular event type from which to unregister the handler.- Overrides:
- removeEventHandlerin class- MenuItem
- Type Parameters:
- E- the specific event class of the handler
- Parameters:
- eventType- the event type from which to unregister
- eventHandler- the handler to unregister
 
 - 
buildEventDispatchChainpublic EventDispatchChain buildEventDispatchChain(EventDispatchChain tail) Construct an event dispatch chain for this target. The event dispatch chain contains event dispatchers which might be interested in processing of events targeted at thisEventTarget. This event target is not automatically added to the chain, so if it wants to process events, it needs to add anEventDispatcherfor itself to the chain.In the case the event target is part of some hierarchy, the chain for it is usually built from event dispatchers collected from the root of the hierarchy to the event target. The event dispatch chain is constructed by modifications to the provided initial event dispatch chain. The returned chain should have the initial chain at its end so the dispatchers should be prepended to the initial chain. The caller shouldn't assume that the initial chain remains unchanged nor that the returned value will reference a different chain. - Specified by:
- buildEventDispatchChainin interface- EventTarget
- Overrides:
- buildEventDispatchChainin class- MenuItem
- Parameters:
- tail- the initial chain to build from
- Returns:
- the resulting event dispatch chain for this target
 
 
- 
 
-