public class MenuBarSkin extends SkinBase<MenuBar>
Default skin implementation for the 
MenuBar control. In essence it is
 a simple toolbar. For the time being there is no overflow behavior and we just
 hide nodes which fall outside the bounds.- Since:
- 9
- See Also:
- MenuBar
- 
Property SummaryProperties Type Property Description ObjectProperty<Pos>containerAlignmentSpecifies the alignment of the menu buttons inside the MenuBar (by default it is Pos.TOP_LEFT).DoublePropertyspacingSpecifies the spacing between menu buttons on the MenuBar.
- 
Constructor SummaryConstructors Constructor Description MenuBarSkin(MenuBar control)Creates a new MenuBarSkin instance, installing the necessary child nodes into the Controlchildrenlist, as well as the necessary input mappings for handling key, mouse, etc events.
- 
Method SummaryModifier and Type Method Description protected doublecomputeMaxHeight(double width, double topInset, double rightInset, double bottomInset, double leftInset)Computes the maximum allowable height of the Skin, based on the provided width.protected doublecomputeMinHeight(double width, double topInset, double rightInset, double bottomInset, double leftInset)Computes the minimum allowable height of the Skin, based on the provided width.protected doublecomputeMinWidth(double height, double topInset, double rightInset, double bottomInset, double leftInset)Computes the minimum allowable width of the Skin, based on the provided height.protected doublecomputePrefHeight(double width, double topInset, double rightInset, double bottomInset, double leftInset)Calculates the preferred height of thisSkinBase.protected doublecomputePrefWidth(double height, double topInset, double rightInset, double bottomInset, double leftInset)Calculates the preferred width of thisSkinBase.ObjectProperty<Pos>containerAlignmentProperty()Specifies the alignment of the menu buttons inside the MenuBar (by default it is Pos.TOP_LEFT).voiddispose()Called by a Skinnable when the Skin is replaced on the Skinnable.static List<CssMetaData<? extends Styleable,?>>getClassCssMetaData()Returns the CssMetaData associated with this class, which may include the CssMetaData of its superclasses.PosgetContainerAlignment()Gets the value of the property containerAlignment.List<CssMetaData<? extends Styleable,?>>getCssMetaData()This method should delegate toNode.getClassCssMetaData()so that a Node's CssMetaData can be accessed without the need for reflection.doublegetSpacing()Gets the value of the property spacing.protected voidlayoutChildren(double x, double y, double w, double h)Called during the layout pass of the scenegraph.protected ObjectqueryAccessibleAttribute(AccessibleAttribute attribute, Object... parameters)This method is called by the assistive technology to request the value for an attribute.voidsetContainerAlignment(Pos value)Sets the value of the property containerAlignment.static voidsetDefaultSystemMenuBar(MenuBar menuBar)Set the default system menu bar.voidsetSpacing(double value)Sets the value of the property spacing.protected doublesnappedBottomInset()Utility method to get the bottom inset which includes padding and border inset.protected doublesnappedLeftInset()Utility method to get the left inset which includes padding and border inset.protected doublesnappedRightInset()Utility method to get the right inset which includes padding and border inset.protected doublesnappedTopInset()Utility method to get the top inset which includes padding and border inset.DoublePropertyspacingProperty()Specifies the spacing between menu buttons on the MenuBar.Methods inherited from class javafx.scene.control.SkinBasecomputeBaselineOffset, computeMaxWidth, consumeMouseEvents, executeAccessibleAction, getChildren, getNode, getSkinnable, layoutInArea, layoutInArea, layoutInArea, positionInArea, positionInArea, pseudoClassStateChanged, registerChangeListener, snapPosition, snapPositionX, snapPositionY, snapSize, snapSizeX, snapSizeY, snapSpace, snapSpaceX, snapSpaceY, unregisterChangeListeners
- 
Property Details- 
spacingSpecifies the spacing between menu buttons on the MenuBar.- See Also:
- getSpacing(),- setSpacing(double)
 
- 
containerAlignmentSpecifies the alignment of the menu buttons inside the MenuBar (by default it is Pos.TOP_LEFT).
 
- 
- 
Constructor Details- 
MenuBarSkinCreates a new MenuBarSkin instance, installing the necessary child nodes into the Controlchildrenlist, as well as the necessary input mappings for handling key, mouse, etc events.- Parameters:
- control- The control that this skin should be installed onto.
 
 
- 
- 
Method Details- 
setDefaultSystemMenuBarSet the default system menu bar. This allows an application to keep menu in the system menu bar after the last Window is closed.- Parameters:
- menuBar- the menu bar
 
- 
setSpacingpublic final void setSpacing(double value)Sets the value of the property spacing.- Property description:
- Specifies the spacing between menu buttons on the MenuBar.
 
- 
getSpacingpublic final double getSpacing()Gets the value of the property spacing.- Property description:
- Specifies the spacing between menu buttons on the MenuBar.
 
- 
spacingPropertySpecifies the spacing between menu buttons on the MenuBar.- See Also:
- getSpacing(),- setSpacing(double)
 
- 
setContainerAlignmentSets the value of the property containerAlignment.- Property description:
- Specifies the alignment of the menu buttons inside the MenuBar (by default it is Pos.TOP_LEFT).
 
- 
getContainerAlignmentGets the value of the property containerAlignment.- Property description:
- Specifies the alignment of the menu buttons inside the MenuBar (by default it is Pos.TOP_LEFT).
 
- 
containerAlignmentPropertySpecifies the alignment of the menu buttons inside the MenuBar (by default it is Pos.TOP_LEFT).
- 
disposepublic void dispose()Called by a Skinnable when the Skin is replaced on the Skinnable. This method allows a Skin to implement any logic necessary to clean up itself after the Skin is no longer needed. It may be used to release native resources. The methodsSkin.getSkinnable()andSkin.getNode()should return null following a call to dispose. Calling dispose twice has no effect.
- 
snappedTopInsetprotected double snappedTopInset()Utility method to get the top inset which includes padding and border inset. Then snapped to whole pixels if getSkinnable().isSnapToPixel() is true.- Overrides:
- snappedTopInsetin class- SkinBase<MenuBar>
- Returns:
- Rounded up insets top
 
- 
snappedBottomInsetprotected double snappedBottomInset()Utility method to get the bottom inset which includes padding and border inset. Then snapped to whole pixels if getSkinnable().isSnapToPixel() is true.- Overrides:
- snappedBottomInsetin class- SkinBase<MenuBar>
- Returns:
- Rounded up insets bottom
 
- 
snappedLeftInsetprotected double snappedLeftInset()Utility method to get the left inset which includes padding and border inset. Then snapped to whole pixels if getSkinnable().isSnapToPixel() is true.- Overrides:
- snappedLeftInsetin class- SkinBase<MenuBar>
- Returns:
- Rounded up insets left
 
- 
snappedRightInsetprotected double snappedRightInset()Utility method to get the right inset which includes padding and border inset. Then snapped to whole pixels if getSkinnable().isSnapToPixel() is true.- Overrides:
- snappedRightInsetin class- SkinBase<MenuBar>
- Returns:
- Rounded up insets right
 
- 
layoutChildrenprotected void layoutChildren(double x, double y, double w, double h)Called during the layout pass of the scenegraph.- Overrides:
- layoutChildrenin class- SkinBase<MenuBar>
- Parameters:
- x- the x position
- y- the y position
- w- the width
- h- the height
 
- 
computeMinWidthprotected double computeMinWidth(double height, double topInset, double rightInset, double bottomInset, double leftInset)Computes the minimum allowable width of the Skin, based on the provided height.- Overrides:
- computeMinWidthin class- SkinBase<MenuBar>
- Parameters:
- height- The height of the Skin, in case this value might dictate the minimum width.
- topInset- the pixel snapped top inset
- rightInset- the pixel snapped right inset
- bottomInset- the pixel snapped bottom inset
- leftInset- the pixel snapped left inset
- Returns:
- A double representing the minimum width of this Skin.
 
- 
computePrefWidthprotected double computePrefWidth(double height, double topInset, double rightInset, double bottomInset, double leftInset)Calculates the preferred width of thisSkinBase. The default implementation calculates this width as the width of the area occupied by its managed children when they are positioned at their current positions at their preferred widths.- Overrides:
- computePrefWidthin class- SkinBase<MenuBar>
- Parameters:
- height- the height that should be used if preferred width depends on it
- topInset- the pixel snapped top inset
- rightInset- the pixel snapped right inset
- bottomInset- the pixel snapped bottom inset
- leftInset- the pixel snapped left inset
- Returns:
- the calculated preferred width
 
- 
computeMinHeightprotected double computeMinHeight(double width, double topInset, double rightInset, double bottomInset, double leftInset)Computes the minimum allowable height of the Skin, based on the provided width.- Overrides:
- computeMinHeightin class- SkinBase<MenuBar>
- Parameters:
- width- The width of the Skin, in case this value might dictate the minimum height.
- topInset- the pixel snapped top inset
- rightInset- the pixel snapped right inset
- bottomInset- the pixel snapped bottom inset
- leftInset- the pixel snapped left inset
- Returns:
- A double representing the minimum height of this Skin.
 
- 
computePrefHeightprotected double computePrefHeight(double width, double topInset, double rightInset, double bottomInset, double leftInset)Calculates the preferred height of thisSkinBase. The default implementation calculates this height as the height of the area occupied by its managed children when they are positioned at their current positions at their preferred heights.- Overrides:
- computePrefHeightin class- SkinBase<MenuBar>
- Parameters:
- width- the width that should be used if preferred height depends on it
- topInset- the pixel snapped top inset
- rightInset- the pixel snapped right inset
- bottomInset- the pixel snapped bottom inset
- leftInset- the pixel snapped left inset
- Returns:
- the calculated preferred height
 
- 
computeMaxHeightprotected double computeMaxHeight(double width, double topInset, double rightInset, double bottomInset, double leftInset)Computes the maximum allowable height of the Skin, based on the provided width.- Overrides:
- computeMaxHeightin class- SkinBase<MenuBar>
- Parameters:
- width- The width of the Skin, in case this value might dictate the maximum height.
- topInset- the pixel snapped top inset
- rightInset- the pixel snapped right inset
- bottomInset- the pixel snapped bottom inset
- leftInset- the pixel snapped left inset
- Returns:
- A double representing the maximum height of this Skin.
 
- 
getClassCssMetaDataReturns the CssMetaData associated with this class, which may include the CssMetaData of its superclasses.- Returns:
- the CssMetaData associated with this class, which may include the CssMetaData of its superclasses
 
- 
getCssMetaDataThis method should delegate toNode.getClassCssMetaData()so that a Node's CssMetaData can be accessed without the need for reflection.- Overrides:
- getCssMetaDatain class- SkinBase<MenuBar>
- Returns:
- The CssMetaData associated with this node, which may include the CssMetaData of its superclasses.
 
- 
queryAccessibleAttributeThis method is called by the assistive technology to request the value for an attribute.This method is commonly overridden by subclasses to implement attributes that are required for a specific role. 
 If a particular attribute is not handled, the superclass implementation must be called.- Overrides:
- queryAccessibleAttributein class- SkinBase<MenuBar>
- Parameters:
- attribute- the requested attribute
- parameters- optional list of parameters
- Returns:
- the value for the requested attribute
- See Also:
- AccessibleAttribute,- Node.queryAccessibleAttribute(javafx.scene.AccessibleAttribute, java.lang.Object...)
 
 
-