- All Implemented Interfaces:
Styleable,EventTarget
- Direct Known Subclasses:
CheckMenuItem,CustomMenuItem,Menu,RadioMenuItem
MenuItem is intended to be used in conjunction with Menu to provide
options to users. MenuItem serves as the base class for the bulk of JavaFX menus
API.
It has a display text property, as well as an optional graphic node
that can be set on it.
The accelerator property enables accessing the
associated action in one keystroke. Also, as with the Button control,
by using the setOnAction(javafx.event.EventHandler<javafx.event.ActionEvent>) method, you can have an instance of MenuItem
perform any action you wish.
Note: Whilst any size of graphic can be inserted into a MenuItem, the most commonly used size in most applications is 16x16 pixels. This is the recommended graphic dimension to use if you're using the default style provided by JavaFX.
To create a MenuItem is simple:
MenuItem menuItem = new MenuItem("Open");
menuItem.setOnAction(e -> System.out.println("Opening Database Connection..."));
Circle graphic = new Circle(8);
graphic.setFill(Color.GREEN);
menuItem.setGraphic(graphic);
Menu menu = new Menu("File");
menu.getItems().add(menuItem);
MenuBar menuBar = new MenuBar(menu);

- Since:
- JavaFX 2.0
- See Also:
-
Property Summary
PropertiesTypePropertyDescriptionfinal ObjectProperty<KeyCombination> The accelerator property enables accessing the associated action in one keystroke.final BooleanPropertySets the individual disabled state of this MenuItem.final ObjectProperty<Node> An optional graphic for theMenuItem.final StringPropertyThe id of this MenuItem.final BooleanPropertyMnemonicParsing property to enable/disable text parsing.final ObjectProperty<EventHandler<ActionEvent>> The action, which is invoked whenever the MenuItem is fired.final ObjectProperty<EventHandler<Event>> The event handler that is associated with invocation of an accelerator for a MenuItem.final ReadOnlyObjectProperty<Menu> This is theMenuin which thisMenuItemexists.This is theContextMenuin which thisMenuItemexists.final StringPropertyA string representation of the CSS style associated with this specific MenuItem.final StringPropertyThe text to display in theMenuItem.final BooleanPropertySpecifies whether this MenuItem should be rendered as part of the scene graph. -
Field Summary
FieldsModifier and TypeFieldDescriptionCalled when a accelerator for the Menuitem is invoked -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal ObjectProperty<KeyCombination> The accelerator property enables accessing the associated action in one keystroke.Construct an event dispatch chain for this target.final BooleanPropertySets the individual disabled state of this MenuItem.voidfire()Fires a new ActionEvent.final KeyCombinationGets the value of theacceleratorproperty.List<CssMetaData<? extends Styleable, ?>> The CssMetaData of this Styleable.final NodeGets the value of thegraphicproperty.final StringgetId()Gets the value of theidproperty.final EventHandler<ActionEvent> Gets the value of theonActionproperty.final EventHandler<Event> Gets the value of theonMenuValidationproperty.final MenuGets the value of theparentMenuproperty.final ContextMenuGets the value of theparentPopupproperty.Returns an observable map of properties on this menu item for use primarily by application developers.final ObservableSet<PseudoClass> Return the pseudo-class state of this Styleable.final StringgetStyle()Gets the value of thestyleproperty.Return the parent of this Styleable, or null if there is no parent.A list of String identifiers which can be used to logically group Nodes, specifically for an external style engine.final StringgetText()Gets the value of thetextproperty.The type of thisStyleablethat is to be used in selector matching.final ObjectProperty<Node> An optional graphic for theMenuItem.final StringPropertyThe id of this MenuItem.final booleanGets the value of thedisableproperty.final booleanGets the value of themnemonicParsingproperty.final booleanGets the value of thevisibleproperty.final BooleanPropertyMnemonicParsing property to enable/disable text parsing.final ObjectProperty<EventHandler<ActionEvent>> The action, which is invoked whenever the MenuItem is fired.final ObjectProperty<EventHandler<Event>> The event handler that is associated with invocation of an accelerator for a MenuItem.final ReadOnlyObjectProperty<Menu> This is theMenuin which thisMenuItemexists.This is theContextMenuin which thisMenuItemexists.final voidsetAccelerator(KeyCombination value) Sets the value of theacceleratorproperty.final voidsetDisable(boolean value) Sets the value of thedisableproperty.final voidsetGraphic(Node value) Sets the value of thegraphicproperty.final voidSets the value of theidproperty.final voidsetMnemonicParsing(boolean value) Sets the value of themnemonicParsingproperty.final voidsetOnAction(EventHandler<ActionEvent> value) Sets the value of theonActionproperty.final voidsetOnMenuValidation(EventHandler<Event> value) Sets the value of theonMenuValidationproperty.protected final voidsetParentMenu(Menu value) Sets the value of theparentMenuproperty.protected final voidsetParentPopup(ContextMenu value) Sets the value of theparentPopupproperty.final voidSets the value of thestyleproperty.final voidSets the value of thetextproperty.voidsetUserData(Object value) Stores a user object that contains data at their discretion.final voidsetVisible(boolean value) Sets the value of thevisibleproperty.final StringPropertyA string representation of the CSS style associated with this specific MenuItem.final StringPropertyThe text to display in theMenuItem.final BooleanPropertySpecifies whether this MenuItem should be rendered as part of the scene graph.Methods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods declared in interface javafx.event.EventTarget
addEventFilter, addEventHandler, removeEventFilter, removeEventHandlerMethods declared in interface javafx.css.Styleable
getStyleableNode
-
Property Details
-
id
The id of this MenuItem. This simple string identifier is useful for finding a specific MenuItem within the scene graph.- See Also:
-
style
A string representation of the CSS style associated with this specific MenuItem. This is analogous to the "style" attribute of an HTML element. Note that, like the HTML style attribute, this variable contains style properties and values and not the selector portion of a style rule.- See Also:
-
parentMenu
This is theMenuin which thisMenuItemexists. It is possible for an instance of this class to not have aparentMenu- this means that this instance is either:- Not yet associated with its
parentMenu. - A 'root'
Menu(i.e. it is a context menu, attached directly to aMenuBar,MenuButton, or any of the other controls that useMenuinternally.
- See Also:
- Not yet associated with its
-
parentPopup
This is theContextMenuin which thisMenuItemexists.- See Also:
-
text
The text to display in theMenuItem.- See Also:
-
graphic
An optional graphic for theMenuItem. This will normally be anImageViewnode, but there is no requirement for this to be the case.- See Also:
-
onAction
The action, which is invoked whenever the MenuItem is fired. This may be due to the user clicking on the button with the mouse, or by a touch event, or by a key press, or if the developer programatically invokes thefire()method.- See Also:
-
onMenuValidation
The event handler that is associated with invocation of an accelerator for a MenuItem. This can happen when a key sequence for an accelerator is pressed. The event handler is also invoked when onShowing event handler is called.- Since:
- JavaFX 2.2
- See Also:
-
disable
Sets the individual disabled state of this MenuItem. Setting disable to true will cause this MenuItem to become disabled.- See Also:
-
visible
Specifies whether this MenuItem should be rendered as part of the scene graph.- See Also:
-
accelerator
The accelerator property enables accessing the associated action in one keystroke. It is a convenience offered to perform quickly a given action.- See Also:
-
mnemonicParsing
MnemonicParsing property to enable/disable text parsing. If this is set to true, then the MenuItem text will be parsed to see if it contains the mnemonic parsing character '_'. When a mnemonic is detected the key combination will be determined based on the succeeding character, and the mnemonic added.The default value for MenuItem is true.
- See Also:
-
-
Field Details
-
MENU_VALIDATION_EVENT
Called when a accelerator for the Menuitem is invoked
- Since:
- JavaFX 2.2
-
-
Constructor Details
-
MenuItem
public MenuItem()Constructs a MenuItem with no display text. -
MenuItem
Constructs a MenuItem and sets the display text with the specified text- Parameters:
text- the display text- See Also:
-
MenuItem
Constructor s MenuItem and sets the display text with the specified text and sets the graphicNodeto the given node.- Parameters:
text- the display textgraphic- the graphic node- See Also:
-
-
Method Details
-
setId
Sets the value of theidproperty.- Property description:
- The id of this MenuItem. This simple string identifier is useful for finding a specific MenuItem within the scene graph.
- Parameters:
value- the value for theidproperty- See Also:
-
getId
Gets the value of theidproperty. -
idProperty
The id of this MenuItem. This simple string identifier is useful for finding a specific MenuItem within the scene graph.- Returns:
- the
idproperty - See Also:
-
setStyle
Sets the value of thestyleproperty.- Property description:
- A string representation of the CSS style associated with this specific MenuItem. This is analogous to the "style" attribute of an HTML element. Note that, like the HTML style attribute, this variable contains style properties and values and not the selector portion of a style rule.
- Parameters:
value- the value for thestyleproperty- See Also:
-
getStyle
Gets the value of thestyleproperty.- Specified by:
getStylein interfaceStyleable- Property description:
- A string representation of the CSS style associated with this specific MenuItem. This is analogous to the "style" attribute of an HTML element. Note that, like the HTML style attribute, this variable contains style properties and values and not the selector portion of a style rule.
- Returns:
- the value of the
styleproperty - See Also:
-
styleProperty
A string representation of the CSS style associated with this specific MenuItem. This is analogous to the "style" attribute of an HTML element. Note that, like the HTML style attribute, this variable contains style properties and values and not the selector portion of a style rule.- Returns:
- the
styleproperty - See Also:
-
setParentMenu
Sets the value of theparentMenuproperty.- Property description:
- This is the
Menuin which thisMenuItemexists. It is possible for an instance of this class to not have aparentMenu- this means that this instance is either:- Not yet associated with its
parentMenu. - A 'root'
Menu(i.e. it is a context menu, attached directly to aMenuBar,MenuButton, or any of the other controls that useMenuinternally.
- Not yet associated with its
- Parameters:
value- the value for theparentMenuproperty- See Also:
-
getParentMenu
Gets the value of theparentMenuproperty.- Property description:
- This is the
Menuin which thisMenuItemexists. It is possible for an instance of this class to not have aparentMenu- this means that this instance is either:- Not yet associated with its
parentMenu. - A 'root'
Menu(i.e. it is a context menu, attached directly to aMenuBar,MenuButton, or any of the other controls that useMenuinternally.
- Not yet associated with its
- Returns:
- the value of the
parentMenuproperty - See Also:
-
parentMenuProperty
This is theMenuin which thisMenuItemexists. It is possible for an instance of this class to not have aparentMenu- this means that this instance is either:- Not yet associated with its
parentMenu. - A 'root'
Menu(i.e. it is a context menu, attached directly to aMenuBar,MenuButton, or any of the other controls that useMenuinternally.
- Returns:
- the
parentMenuproperty - See Also:
- Not yet associated with its
-
setParentPopup
Sets the value of theparentPopupproperty.- Property description:
- This is the
ContextMenuin which thisMenuItemexists. - Parameters:
value- the value for theparentPopupproperty- See Also:
-
getParentPopup
Gets the value of theparentPopupproperty.- Property description:
- This is the
ContextMenuin which thisMenuItemexists. - Returns:
- the value of the
parentPopupproperty - See Also:
-
parentPopupProperty
This is theContextMenuin which thisMenuItemexists.- Returns:
- the
parentPopupproperty - See Also:
-
setText
Sets the value of thetextproperty.- Property description:
- The text to display in the
MenuItem. - Parameters:
value- the value for thetextproperty- See Also:
-
getText
Gets the value of thetextproperty.- Property description:
- The text to display in the
MenuItem. - Returns:
- the value of the
textproperty - See Also:
-
textProperty
The text to display in theMenuItem.- Returns:
- the
textproperty - See Also:
-
setGraphic
Sets the value of thegraphicproperty.- Property description:
- An optional graphic for the
MenuItem. This will normally be anImageViewnode, but there is no requirement for this to be the case. - Parameters:
value- the value for thegraphicproperty- See Also:
-
getGraphic
Gets the value of thegraphicproperty.- Property description:
- An optional graphic for the
MenuItem. This will normally be anImageViewnode, but there is no requirement for this to be the case. - Returns:
- the value of the
graphicproperty - See Also:
-
graphicProperty
An optional graphic for theMenuItem. This will normally be anImageViewnode, but there is no requirement for this to be the case.- Returns:
- the
graphicproperty - See Also:
-
setOnAction
Sets the value of theonActionproperty.- Property description:
- The action, which is invoked whenever the MenuItem is fired. This
may be due to the user clicking on the button with the mouse, or by
a touch event, or by a key press, or if the developer programatically
invokes the
fire()method. - Parameters:
value- the value for theonActionproperty- See Also:
-
getOnAction
Gets the value of theonActionproperty.- Property description:
- The action, which is invoked whenever the MenuItem is fired. This
may be due to the user clicking on the button with the mouse, or by
a touch event, or by a key press, or if the developer programatically
invokes the
fire()method. - Returns:
- the value of the
onActionproperty - See Also:
-
onActionProperty
The action, which is invoked whenever the MenuItem is fired. This may be due to the user clicking on the button with the mouse, or by a touch event, or by a key press, or if the developer programatically invokes thefire()method.- Returns:
- the
onActionproperty - See Also:
-
setOnMenuValidation
Sets the value of theonMenuValidationproperty.- Property description:
- The event handler that is associated with invocation of an accelerator for a MenuItem. This can happen when a key sequence for an accelerator is pressed. The event handler is also invoked when onShowing event handler is called.
- Parameters:
value- the value for theonMenuValidationproperty- Since:
- JavaFX 2.2
- See Also:
-
getOnMenuValidation
Gets the value of theonMenuValidationproperty.- Property description:
- The event handler that is associated with invocation of an accelerator for a MenuItem. This can happen when a key sequence for an accelerator is pressed. The event handler is also invoked when onShowing event handler is called.
- Returns:
- the value of the
onMenuValidationproperty - Since:
- JavaFX 2.2
- See Also:
-
onMenuValidationProperty
The event handler that is associated with invocation of an accelerator for a MenuItem. This can happen when a key sequence for an accelerator is pressed. The event handler is also invoked when onShowing event handler is called.- Returns:
- the
onMenuValidationproperty - Since:
- JavaFX 2.2
- See Also:
-
setDisable
public final void setDisable(boolean value) Sets the value of thedisableproperty.- Property description:
- Sets the individual disabled state of this MenuItem. Setting disable to true will cause this MenuItem to become disabled.
- Parameters:
value- the value for thedisableproperty- See Also:
-
isDisable
public final boolean isDisable()Gets the value of thedisableproperty.- Property description:
- Sets the individual disabled state of this MenuItem. Setting disable to true will cause this MenuItem to become disabled.
- Returns:
- the value of the
disableproperty - See Also:
-
disableProperty
Sets the individual disabled state of this MenuItem. Setting disable to true will cause this MenuItem to become disabled.- Returns:
- the
disableproperty - See Also:
-
setVisible
public final void setVisible(boolean value) Sets the value of thevisibleproperty.- Property description:
- Specifies whether this MenuItem should be rendered as part of the scene graph.
- Parameters:
value- the value for thevisibleproperty- See Also:
-
isVisible
public final boolean isVisible()Gets the value of thevisibleproperty.- Property description:
- Specifies whether this MenuItem should be rendered as part of the scene graph.
- Returns:
- the value of the
visibleproperty - See Also:
-
visibleProperty
Specifies whether this MenuItem should be rendered as part of the scene graph.- Returns:
- the
visibleproperty - See Also:
-
setAccelerator
Sets the value of theacceleratorproperty.- Property description:
- The accelerator property enables accessing the associated action in one keystroke. It is a convenience offered to perform quickly a given action.
- Parameters:
value- the value for theacceleratorproperty- See Also:
-
getAccelerator
Gets the value of theacceleratorproperty.- Property description:
- The accelerator property enables accessing the associated action in one keystroke. It is a convenience offered to perform quickly a given action.
- Returns:
- the value of the
acceleratorproperty - See Also:
-
acceleratorProperty
The accelerator property enables accessing the associated action in one keystroke. It is a convenience offered to perform quickly a given action.- Returns:
- the
acceleratorproperty - See Also:
-
setMnemonicParsing
public final void setMnemonicParsing(boolean value) Sets the value of themnemonicParsingproperty.- Property description:
- MnemonicParsing property to enable/disable text parsing.
If this is set to true, then the MenuItem text will be
parsed to see if it contains the mnemonic parsing character '_'.
When a mnemonic is detected the key combination will
be determined based on the succeeding character, and the mnemonic
added.
The default value for MenuItem is true.
- Parameters:
value- the value for themnemonicParsingproperty- See Also:
-
isMnemonicParsing
public final boolean isMnemonicParsing()Gets the value of themnemonicParsingproperty.- Property description:
- MnemonicParsing property to enable/disable text parsing.
If this is set to true, then the MenuItem text will be
parsed to see if it contains the mnemonic parsing character '_'.
When a mnemonic is detected the key combination will
be determined based on the succeeding character, and the mnemonic
added.
The default value for MenuItem is true.
- Returns:
- the value of the
mnemonicParsingproperty - See Also:
-
mnemonicParsingProperty
MnemonicParsing property to enable/disable text parsing. If this is set to true, then the MenuItem text will be parsed to see if it contains the mnemonic parsing character '_'. When a mnemonic is detected the key combination will be determined based on the succeeding character, and the mnemonic added.The default value for MenuItem is true.
- Returns:
- the
mnemonicParsingproperty - See Also:
-
getStyleClass
Description copied from interface:StyleableA list of String identifiers which can be used to logically group Nodes, specifically for an external style engine. This variable is analogous to the "class" attribute on an HTML element and, as such, each element of the list is a style class to which this Node belongs.- Specified by:
getStyleClassin interfaceStyleable- Returns:
- a list of String identifiers which can be used to logically group Nodes, specifically for an external style engine
- See Also:
-
fire
public void fire()Fires a new ActionEvent. -
buildEventDispatchChain
Description copied from interface:EventTargetConstruct 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 interfaceEventTarget- Parameters:
tail- the initial chain to build from- Returns:
- the resulting event dispatch chain for this target
-
getUserData
- Returns:
- the user object that was stored (including
null), ornullif no object has been set
-
setUserData
Stores a user object that contains data at their discretion. It can later be retrieved by callinggetUserData().- Parameters:
value- the user object to be stored
-
getProperties
Returns an observable map of properties on this menu item for use primarily by application developers.- Returns:
- an observable map of properties on this menu item for use primarily by application developers
-
getTypeSelector
The type of thisStyleablethat is to be used in selector matching. This is analogous to an "element" in HTML. (CSS Type Selector).- Specified by:
getTypeSelectorin interfaceStyleable- Returns:
- "MenuItem"
- Since:
- JavaFX 8.0
-
getStyleableParent
Return the parent of this Styleable, or null if there is no parent.- Specified by:
getStyleableParentin interfaceStyleable- Returns:
getParentMenu(), orgetParentPopup()ifparentMenuis null- Since:
- JavaFX 8.0
-
getPseudoClassStates
Return the pseudo-class state of this Styleable. CSS assumes this set is read-only.- Specified by:
getPseudoClassStatesin interfaceStyleable- Returns:
- the pseudo-class state
- Since:
- JavaFX 8.0
-
getCssMetaData
Description copied from interface:StyleableThe CssMetaData of this Styleable. This may be returned as an unmodifiable list.- Specified by:
getCssMetaDatain interfaceStyleable- Returns:
- the CssMetaData
-