- java.lang.Object
- 
- javafx.scene.Node
- 
- javafx.scene.Parent
- 
- javafx.scene.layout.Region
- 
- javafx.scene.control.Control
 
 
 
 
- 
- All Implemented Interfaces:
- Styleable,- EventTarget,- Skinnable
 - Direct Known Subclasses:
- Accordion,- ButtonBar,- ChoiceBox,- ComboBoxBase,- HTMLEditor,- Labeled,- ListView,- MenuBar,- Pagination,- ProgressIndicator,- ScrollBar,- ScrollPane,- Separator,- Slider,- Spinner,- SplitPane,- TableView,- TabPane,- TextInputControl,- ToolBar,- TreeTableView,- TreeView
 
 public abstract class Control extends Region implements Skinnable Base class for all user interface controls. A "Control" is a node in the scene graph which can be manipulated by the user. Controls provide additional variables and behaviors beyond those of Node to support common user interactions in a manner which is consistent and predictable for the user.Additionally, controls support explicit skinning to make it easy to leverage the functionality of a control while customizing its appearance. See specific Control subclasses for information on how to use individual types of controls. Most controls have their focusTraversable property set to true by default, however read-only controls such as LabelandProgressIndicator, and some controls that are containersScrollPaneandToolBardo not. Consult individual control documentation for details.- Since:
- JavaFX 2.0
 
- 
- 
Property SummaryProperties Type Property Description ObjectProperty<ContextMenu>contextMenuThe ContextMenu to show for this control.ObjectProperty<Skin<?>>skinSkin is responsible for rendering thisControl.ObjectProperty<Tooltip>tooltipThe ToolTip for this control.- 
Properties inherited from class javafx.scene.layout.Regionbackground, border, cacheShape, centerShape, height, insets, maxHeight, maxWidth, minHeight, minWidth, opaqueInsets, padding, prefHeight, prefWidth, scaleShape, shape, snapToPixel, width
 - 
Properties inherited from class javafx.scene.ParentneedsLayout
 - 
Properties inherited from class javafx.scene.NodeaccessibleHelp, accessibleRoleDescription, accessibleRole, accessibleText, blendMode, boundsInLocal, boundsInParent, cacheHint, cache, clip, cursor, depthTest, disabled, disable, effectiveNodeOrientation, effect, eventDispatcher, focused, focusTraversable, hover, id, inputMethodRequests, layoutBounds, layoutX, layoutY, localToParentTransform, localToSceneTransform, managed, mouseTransparent, nodeOrientation, onContextMenuRequested, onDragDetected, onDragDone, onDragDropped, onDragEntered, onDragExited, onDragOver, onInputMethodTextChanged, onKeyPressed, onKeyReleased, onKeyTyped, onMouseClicked, onMouseDragEntered, onMouseDragExited, onMouseDragged, onMouseDragOver, onMouseDragReleased, onMouseEntered, onMouseExited, onMouseMoved, onMousePressed, onMouseReleased, onRotate, onRotationFinished, onRotationStarted, onScrollFinished, onScroll, onScrollStarted, onSwipeDown, onSwipeLeft, onSwipeRight, onSwipeUp, onTouchMoved, onTouchPressed, onTouchReleased, onTouchStationary, onZoomFinished, onZoom, onZoomStarted, opacity, parent, pickOnBounds, pressed, rotate, rotationAxis, scaleX, scaleY, scaleZ, scene, style, translateX, translateY, translateZ, viewOrder, visible
 
- 
 - 
Field Summary- 
Fields inherited from class javafx.scene.layout.RegionUSE_COMPUTED_SIZE, USE_PREF_SIZE
 - 
Fields inherited from class javafx.scene.NodeBASELINE_OFFSET_SAME_AS_HEIGHT
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedControl()Create a new Control.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected doublecomputeMaxHeight(double width)Computes the maximum allowable height of the Control, based on the provided width.protected doublecomputeMaxWidth(double height)Computes the maximum allowable width of the Control, based on the provided height.protected doublecomputeMinHeight(double width)Computes the minimum allowable height of the Control, based on the provided width.protected doublecomputeMinWidth(double height)Computes the minimum allowable width of the Control, based on the provided height.protected doublecomputePrefHeight(double width)Computes the preferred height of this region for the given width; Region subclasses should override this method to return an appropriate value based on their content and layout strategy.protected doublecomputePrefWidth(double height)Computes the preferred width of this region for the given height.ObjectProperty<ContextMenu>contextMenuProperty()The ContextMenu to show for this control.protected Skin<?>createDefaultSkin()Create a new instance of the default skin for this control.voidexecuteAccessibleAction(AccessibleAction action, Object... parameters)This method is called by the assistive technology to request the action indicated by the argument should be executed.doublegetBaselineOffset()Calculates the baseline offset based on the first managed child.static List<CssMetaData<? extends Styleable,?>>getClassCssMetaData()ContextMenugetContextMenu()Gets the value of the property contextMenu.protected List<CssMetaData<? extends Styleable,?>>getControlCssMetaData()List<CssMetaData<? extends Styleable,?>>getCssMetaData()This method returns aListcontaining allCssMetaDatafor both this Control (returned fromgetControlCssMetaData()and itsSkin, assuming theskin propertyis aSkinBase.protected BooleangetInitialFocusTraversable()Returns the initial focus traversable state of this control, for use by the JavaFX CSS engine to correctly set its initial value.Skin<?>getSkin()Gets the value of the property skin.TooltipgetTooltip()Gets the value of the property tooltip.booleanisResizable()Returnstruesince all Controls are resizable.protected voidlayoutChildren()Invoked during the layout pass to layout the children in thisParent.ObjectqueryAccessibleAttribute(AccessibleAttribute attribute, Object... parameters)This method is called by the assistive technology to request the value for an attribute.voidsetContextMenu(ContextMenu value)Sets the value of the property contextMenu.voidsetSkin(Skin<?> value)Sets the value of the property skin.voidsetTooltip(Tooltip value)Sets the value of the property tooltip.ObjectProperty<Skin<?>>skinProperty()Skin is responsible for rendering thisControl.ObjectProperty<Tooltip>tooltipProperty()The ToolTip for this control.- 
Methods inherited from class javafx.scene.layout.RegionbackgroundProperty, borderProperty, cacheShapeProperty, centerShapeProperty, getBackground, getBorder, getHeight, getInsets, getMaxHeight, getMaxWidth, getMinHeight, getMinWidth, getOpaqueInsets, getPadding, getPrefHeight, getPrefWidth, getShape, getUserAgentStylesheet, getWidth, heightProperty, insetsProperty, isCacheShape, isCenterShape, isScaleShape, isSnapToPixel, layoutInArea, layoutInArea, layoutInArea, layoutInArea, maxHeight, maxHeightProperty, maxWidth, maxWidthProperty, minHeight, minHeightProperty, minWidth, minWidthProperty, opaqueInsetsProperty, paddingProperty, positionInArea, positionInArea, prefHeight, prefHeightProperty, prefWidth, prefWidthProperty, resize, scaleShapeProperty, setBackground, setBorder, setCacheShape, setCenterShape, setHeight, setMaxHeight, setMaxSize, setMaxWidth, setMinHeight, setMinSize, setMinWidth, setOpaqueInsets, setPadding, setPrefHeight, setPrefSize, setPrefWidth, setScaleShape, setShape, setSnapToPixel, setWidth, shapeProperty, snappedBottomInset, snappedLeftInset, snappedRightInset, snappedTopInset, snapPosition, snapPositionX, snapPositionY, snapSize, snapSizeX, snapSizeY, snapSpace, snapSpaceX, snapSpaceY, snapToPixelProperty, widthProperty
 - 
Methods inherited from class javafx.scene.ParentgetChildren, getChildrenUnmodifiable, getManagedChildren, getStylesheets, isNeedsLayout, layout, lookup, needsLayoutProperty, requestLayout, requestParentLayout, setNeedsLayout, updateBounds
 - 
Methods inherited from class javafx.scene.NodeaccessibleHelpProperty, accessibleRoleDescriptionProperty, accessibleRoleProperty, accessibleTextProperty, addEventFilter, addEventHandler, applyCss, autosize, blendModeProperty, boundsInLocalProperty, boundsInParentProperty, buildEventDispatchChain, cacheHintProperty, cacheProperty, clipProperty, computeAreaInScreen, contains, contains, cursorProperty, depthTestProperty, disabledProperty, disableProperty, effectiveNodeOrientationProperty, effectProperty, eventDispatcherProperty, fireEvent, focusedProperty, focusTraversableProperty, getAccessibleHelp, getAccessibleRole, getAccessibleRoleDescription, getAccessibleText, getBlendMode, getBoundsInLocal, getBoundsInParent, getCacheHint, getClip, getContentBias, getCursor, getDepthTest, getEffect, getEffectiveNodeOrientation, getEventDispatcher, getId, getInitialCursor, getInputMethodRequests, getLayoutBounds, getLayoutX, getLayoutY, getLocalToParentTransform, getLocalToSceneTransform, getNodeOrientation, getOnContextMenuRequested, getOnDragDetected, getOnDragDone, getOnDragDropped, getOnDragEntered, getOnDragExited, getOnDragOver, getOnInputMethodTextChanged, getOnKeyPressed, getOnKeyReleased, getOnKeyTyped, getOnMouseClicked, getOnMouseDragEntered, getOnMouseDragExited, getOnMouseDragged, getOnMouseDragOver, getOnMouseDragReleased, getOnMouseEntered, getOnMouseExited, getOnMouseMoved, getOnMousePressed, getOnMouseReleased, getOnRotate, getOnRotationFinished, getOnRotationStarted, getOnScroll, getOnScrollFinished, getOnScrollStarted, getOnSwipeDown, getOnSwipeLeft, getOnSwipeRight, getOnSwipeUp, getOnTouchMoved, getOnTouchPressed, getOnTouchReleased, getOnTouchStationary, getOnZoom, getOnZoomFinished, getOnZoomStarted, getOpacity, getParent, getProperties, getPseudoClassStates, getRotate, getRotationAxis, getScaleX, getScaleY, getScaleZ, getScene, getStyle, getStyleableParent, getStyleClass, getTransforms, getTranslateX, getTranslateY, getTranslateZ, getTypeSelector, getUserData, getViewOrder, hasProperties, hoverProperty, idProperty, inputMethodRequestsProperty, intersects, intersects, isCache, isDisable, isDisabled, isFocused, isFocusTraversable, isHover, isManaged, isMouseTransparent, isPickOnBounds, isPressed, isVisible, layoutBoundsProperty, layoutXProperty, layoutYProperty, localToParent, localToParent, localToParent, localToParent, localToParent, localToParentTransformProperty, localToScene, localToScene, localToScene, localToScene, localToScene, localToScene, localToScene, localToScene, localToScene, localToScene, localToSceneTransformProperty, localToScreen, localToScreen, localToScreen, localToScreen, localToScreen, lookupAll, managedProperty, mouseTransparentProperty, nodeOrientationProperty, notifyAccessibleAttributeChanged, onContextMenuRequestedProperty, onDragDetectedProperty, onDragDoneProperty, onDragDroppedProperty, onDragEnteredProperty, onDragExitedProperty, onDragOverProperty, onInputMethodTextChangedProperty, onKeyPressedProperty, onKeyReleasedProperty, onKeyTypedProperty, onMouseClickedProperty, onMouseDragEnteredProperty, onMouseDragExitedProperty, onMouseDraggedProperty, onMouseDragOverProperty, onMouseDragReleasedProperty, onMouseEnteredProperty, onMouseExitedProperty, onMouseMovedProperty, onMousePressedProperty, onMouseReleasedProperty, onRotateProperty, onRotationFinishedProperty, onRotationStartedProperty, onScrollFinishedProperty, onScrollProperty, onScrollStartedProperty, onSwipeDownProperty, onSwipeLeftProperty, onSwipeRightProperty, onSwipeUpProperty, onTouchMovedProperty, onTouchPressedProperty, onTouchReleasedProperty, onTouchStationaryProperty, onZoomFinishedProperty, onZoomProperty, onZoomStartedProperty, opacityProperty, parentProperty, parentToLocal, parentToLocal, parentToLocal, parentToLocal, parentToLocal, pickOnBoundsProperty, pressedProperty, pseudoClassStateChanged, relocate, removeEventFilter, removeEventHandler, requestFocus, resizeRelocate, rotateProperty, rotationAxisProperty, scaleXProperty, scaleYProperty, scaleZProperty, sceneProperty, sceneToLocal, sceneToLocal, sceneToLocal, sceneToLocal, sceneToLocal, sceneToLocal, sceneToLocal, sceneToLocal, screenToLocal, screenToLocal, screenToLocal, setAccessibleHelp, setAccessibleRole, setAccessibleRoleDescription, setAccessibleText, setBlendMode, setCache, setCacheHint, setClip, setCursor, setDepthTest, setDisable, setDisabled, setEffect, setEventDispatcher, setEventHandler, setFocused, setFocusTraversable, setHover, setId, setInputMethodRequests, setLayoutX, setLayoutY, setManaged, setMouseTransparent, setNodeOrientation, setOnContextMenuRequested, setOnDragDetected, setOnDragDone, setOnDragDropped, setOnDragEntered, setOnDragExited, setOnDragOver, setOnInputMethodTextChanged, setOnKeyPressed, setOnKeyReleased, setOnKeyTyped, setOnMouseClicked, setOnMouseDragEntered, setOnMouseDragExited, setOnMouseDragged, setOnMouseDragOver, setOnMouseDragReleased, setOnMouseEntered, setOnMouseExited, setOnMouseMoved, setOnMousePressed, setOnMouseReleased, setOnRotate, setOnRotationFinished, setOnRotationStarted, setOnScroll, setOnScrollFinished, setOnScrollStarted, setOnSwipeDown, setOnSwipeLeft, setOnSwipeRight, setOnSwipeUp, setOnTouchMoved, setOnTouchPressed, setOnTouchReleased, setOnTouchStationary, setOnZoom, setOnZoomFinished, setOnZoomStarted, setOpacity, setPickOnBounds, setPressed, setRotate, setRotationAxis, setScaleX, setScaleY, setScaleZ, setStyle, setTranslateX, setTranslateY, setTranslateZ, setUserData, setViewOrder, setVisible, snapshot, snapshot, startDragAndDrop, startFullDrag, styleProperty, toBack, toFront, toString, translateXProperty, translateYProperty, translateZProperty, usesMirroring, viewOrderProperty, visibleProperty
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface javafx.css.StyleablegetStyleableNode
 
- 
 
- 
- 
- 
Property Detail- 
skinpublic final ObjectProperty<Skin<?>> skinProperty Skin is responsible for rendering thisControl. From the perspective of theControl, theSkinis a black box. It listens and responds to changes in state in aControl.There is a one-to-one relationship between a Controland itsSkin. EverySkinmaintains a back reference to theControlvia theSkin.getSkinnable()method.A skin may be null. - Specified by:
- skinPropertyin interface- Skinnable
- See Also:
- getSkin(),- setSkin(Skin)
 
 - 
tooltippublic final ObjectProperty<Tooltip> tooltipProperty The ToolTip for this control.- See Also:
- getTooltip(),- setTooltip(Tooltip)
 
 - 
contextMenupublic final ObjectProperty<ContextMenu> contextMenuProperty The ContextMenu to show for this control.- See Also:
- getContextMenu(),- setContextMenu(ContextMenu)
 
 
- 
 - 
Method Detail- 
skinPropertypublic final ObjectProperty<Skin<?>> skinProperty() Skin is responsible for rendering thisControl. From the perspective of theControl, theSkinis a black box. It listens and responds to changes in state in aControl.There is a one-to-one relationship between a Controland itsSkin. EverySkinmaintains a back reference to theControlvia theSkin.getSkinnable()method.A skin may be null. - Specified by:
- skinPropertyin interface- Skinnable
- See Also:
- getSkin(),- setSkin(Skin)
 
 - 
setSkinpublic final void setSkin(Skin<?> value) Sets the value of the property skin.- Specified by:
- setSkinin interface- Skinnable
- Property description:
- Skin is responsible for rendering this Control. From the perspective of theControl, theSkinis a black box. It listens and responds to changes in state in aControl.There is a one-to-one relationship between a Controland itsSkin. EverySkinmaintains a back reference to theControlvia theSkin.getSkinnable()method.A skin may be null. 
- Parameters:
- value- the skin value for this control
 
 - 
getSkinpublic final Skin<?> getSkin() Gets the value of the property skin.- Specified by:
- getSkinin interface- Skinnable
- Property description:
- Skin is responsible for rendering this Control. From the perspective of theControl, theSkinis a black box. It listens and responds to changes in state in aControl.There is a one-to-one relationship between a Controland itsSkin. EverySkinmaintains a back reference to theControlvia theSkin.getSkinnable()method.A skin may be null. 
- Returns:
- the skin for this control
 
 - 
tooltipPropertypublic final ObjectProperty<Tooltip> tooltipProperty() The ToolTip for this control.- See Also:
- getTooltip(),- setTooltip(Tooltip)
 
 - 
setTooltippublic final void setTooltip(Tooltip value) Sets the value of the property tooltip.- Property description:
- The ToolTip for this control.
 
 - 
getTooltippublic final Tooltip getTooltip() Gets the value of the property tooltip.- Property description:
- The ToolTip for this control.
 
 - 
contextMenuPropertypublic final ObjectProperty<ContextMenu> contextMenuProperty() The ContextMenu to show for this control.- See Also:
- getContextMenu(),- setContextMenu(ContextMenu)
 
 - 
setContextMenupublic final void setContextMenu(ContextMenu value) Sets the value of the property contextMenu.- Property description:
- The ContextMenu to show for this control.
 
 - 
getContextMenupublic final ContextMenu getContextMenu() Gets the value of the property contextMenu.- Property description:
- The ContextMenu to show for this control.
 
 - 
isResizablepublic boolean isResizable() Returnstruesince all Controls are resizable.- Overrides:
- isResizablein class- Region
- Returns:
- whether this node can be resized by its parent during layout
- See Also:
- Node.getContentBias(),- Node.minWidth(double),- Node.minHeight(double),- Node.prefWidth(double),- Node.prefHeight(double),- Node.maxWidth(double),- Node.maxHeight(double),- Node.resize(double, double),- Node.getLayoutBounds()
 
 - 
computeMinWidthprotected double computeMinWidth(double height) Computes the minimum allowable width of the Control, based on the provided height. The minimum width is not calculated within the Control, instead the calculation is delegated to theNode.minWidth(double)method of theSkin. If the Skin is null, the returned value is 0.- Overrides:
- computeMinWidthin class- Region
- Parameters:
- height- The height of the Control, in case this value might dictate the minimum width.
- Returns:
- A double representing the minimum width of this control.
 
 - 
computeMinHeightprotected double computeMinHeight(double width) Computes the minimum allowable height of the Control, based on the provided width. The minimum height is not calculated within the Control, instead the calculation is delegated to theNode.minHeight(double)method of theSkin. If the Skin is null, the returned value is 0.- Overrides:
- computeMinHeightin class- Region
- Parameters:
- width- The width of the Control, in case this value might dictate the minimum height.
- Returns:
- A double representing the minimum height of this control.
 
 - 
computeMaxWidthprotected double computeMaxWidth(double height) Computes the maximum allowable width of the Control, based on the provided height. The maximum width is not calculated within the Control, instead the calculation is delegated to theNode.maxWidth(double)method of theSkin. If the Skin is null, the returned value is 0.- Overrides:
- computeMaxWidthin class- Region
- Parameters:
- height- The height of the Control, in case this value might dictate the maximum width.
- Returns:
- A double representing the maximum width of this control.
 
 - 
computeMaxHeightprotected double computeMaxHeight(double width) Computes the maximum allowable height of the Control, based on the provided width. The maximum height is not calculated within the Control, instead the calculation is delegated to theNode.maxHeight(double)method of theSkin. If the Skin is null, the returned value is 0.- Overrides:
- computeMaxHeightin class- Region
- Parameters:
- width- The width of the Control, in case this value might dictate the maximum height.
- Returns:
- A double representing the maximum height of this control.
 
 - 
computePrefWidthprotected double computePrefWidth(double height) Computes the preferred width of this region for the given height. Region subclasses should override this method to return an appropriate value based on their content and layout strategy. If the subclass doesn't have a VERTICAL content bias, then the height parameter can be ignored.- Overrides:
- computePrefWidthin class- Region
- Parameters:
- height- the height that should be used if preferred width depends on it
- Returns:
- the computed preferred width for this region
 
 - 
computePrefHeightprotected double computePrefHeight(double width) Computes the preferred height of this region for the given width; Region subclasses should override this method to return an appropriate value based on their content and layout strategy. If the subclass doesn't have a HORIZONTAL content bias, then the width parameter can be ignored.- Overrides:
- computePrefHeightin class- Region
- Parameters:
- width- the width that should be used if preferred height depends on it
- Returns:
- the computed preferred height for this region
 
 - 
getBaselineOffsetpublic double getBaselineOffset() Calculates the baseline offset based on the first managed child. If there is no such child, returnsNode.getBaselineOffset().- Overrides:
- getBaselineOffsetin class- Parent
- Returns:
- baseline offset
 
 - 
layoutChildrenprotected void layoutChildren() Invoked during the layout pass to layout the children in thisParent. By default it will only set the size of managed, resizable content to their preferred sizes and does not do any node positioning.Subclasses should override this function to layout content as needed. - Overrides:
- layoutChildrenin class- Parent
 
 - 
createDefaultSkinprotected Skin<?> createDefaultSkin() Create a new instance of the default skin for this control. This is called to create a skin for the control if no skin is provided via CSS-fx-skinor set explicitly in a sub-class withsetSkin(...).- Returns:
- new instance of default skin for this control. If null then the control will have no skin unless one is provided by css.
- Since:
- JavaFX 8.0
 
 - 
getClassCssMetaDatapublic static List<CssMetaData<? extends Styleable,?>> getClassCssMetaData() - Returns:
- The CssMetaData associated with this class, which may include the CssMetaData of its superclasses.
- Since:
- JavaFX 8.0
 
 - 
getCssMetaDatapublic final List<CssMetaData<? extends Styleable,?>> getCssMetaData() This method returns aListcontaining allCssMetaDatafor both this Control (returned fromgetControlCssMetaData()and itsSkin, assuming theskin propertyis aSkinBase.Developers who wish to provide custom CssMetaData are therefore encouraged to override getControlCssMetaData()orSkinBase.getCssMetaData(), depending on where the CssMetaData resides.- Specified by:
- getCssMetaDatain interface- Styleable
- Overrides:
- getCssMetaDatain class- Region
- Returns:
- The CssMetaData associated with this node, which may include the CssMetaData of its superclasses.
- Since:
- JavaFX 8.0
 
 - 
getControlCssMetaDataprotected List<CssMetaData<? extends Styleable,?>> getControlCssMetaData() - Returns:
- unmodifiable list of the controls css styleable properties
- Since:
- JavaFX 8.0
 
 - 
getInitialFocusTraversableprotected Boolean getInitialFocusTraversable() Returns the initial focus traversable state of this control, for use by the JavaFX CSS engine to correctly set its initial value. By default all UI controls are focus traversable, so this method is overridden in Control to set the initial traversable state to true.- Overrides:
- getInitialFocusTraversablein class- Node
- Returns:
- the initial focus traversable state of this control
- Since:
- 9
 
 - 
queryAccessibleAttributepublic Object queryAccessibleAttribute(AccessibleAttribute attribute, Object... parameters) This 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- Parent
- Parameters:
- attribute- the requested attribute
- parameters- optional list of parameters
- Returns:
- the value for the requested attribute
- See Also:
- AccessibleAttribute
 
 - 
executeAccessibleActionpublic void executeAccessibleAction(AccessibleAction action, Object... parameters) This method is called by the assistive technology to request the action indicated by the argument should be executed.This method is commonly overridden by subclasses to implement action that are required for a specific role. 
 If a particular action is not handled, the superclass implementation must be called.- Overrides:
- executeAccessibleActionin class- Node
- Parameters:
- action- the action to execute
- parameters- optional list of parameters
- See Also:
- AccessibleAction
 
 
- 
 
-