- java.lang.Object
-
- javafx.scene.Node
-
- javafx.scene.Parent
-
- javafx.scene.layout.Region
-
- javafx.scene.layout.Pane
-
- javafx.scene.control.DialogPane
-
- All Implemented Interfaces:
Styleable
,EventTarget
@DefaultProperty("buttonTypes") public class DialogPane extends Pane
DialogPane should be considered to be the root node displayed within aDialog
instance. In this role, the DialogPane is responsible for the placement ofheaders
,graphics
,content
, andbuttons
. The default implementation of DialogPane (that is, the DialogPane class itself) handles the layout via the normallayoutChildren()
method. This method may be overridden by subclasses wishing to handle the layout in an alternative fashion).In addition to the
header
andcontent
properties, there existsheader text
andcontent text
properties. The way the *Text properties work is that they are a lower precedence compared to the Node properties, but they are far more convenient for developers in the common case, as it is likely the case that a developer more often than not simply wants to set a string value into the header or content areas of the DialogPane.It is important to understand the implications of setting non-null values in the
header
andheaderText
properties. The key points are as follows:- The
header
property takes precedence over theheaderText
property, so if both are set to non-null values,header
will be used andheaderText
will be ignored. - If
headerText
is set to a non-null value, and agraphic
has also been set, the default position for the graphic shifts from being located to the left of the content area to being to the right of the header text. - If
header
is set to a non-null value, and agraphic
has also been set, the graphic is removed from its default position (to the left of the content area), and is not placed to the right of the custom header node. If the graphic is desired, it should be manually added in to the layout of the custom header node manually.
DialogPane operates on the concept of
ButtonType
. A ButtonType is a descriptor of a single button that should be represented visually in the DialogPane. Developers who create a DialogPane therefore must specify the button types that they want to display, and this is done via thegetButtonTypes()
method, which returns a modifiableObservableList
, which users can add to and remove from as desired.The
ButtonType
class defines a number of pre-defined button types, such asButtonType.OK
andButtonType.CANCEL
. Many users of the JavaFX dialogs API will find that these pre-defined button types meet their needs, particularly due to their built-in support fordefault
andcancel
buttons, as well as the benefit of the strings being translated into all languages which JavaFX is translated to. For users that want to define their ownButtonType
(most commonly to define a button with custom text), they may do so via the constructors available on theButtonType
class.Developers will quickly find that the amount of configurability offered via the
ButtonType
class is minimal. This is intentional, but does not mean that developers can not modify the buttons created by theButtonType
that have been specified. To do this, developers simply call thelookupButton(ButtonType)
method with the ButtonType (assuming it has already been set in thegetButtonTypes()
list. The returned Node is typically of typeButton
, but this depends on if thecreateButton(ButtonType)
method has been overridden.The DialogPane class offers a few methods that can be overridden by subclasses, to more easily enable custom functionality. These methods include the following:
These methods are documented, so please take note of the expectations placed on any developer who wishes to override these methods with their own functionality.
- Since:
- JavaFX 8u40
- See Also:
Dialog
-
-
Property Summary
Properties Type Property Description ObjectProperty<Node>
content
Property representing the content area of the dialog.StringProperty
contentText
A property representing the content text for the dialog pane.ObjectProperty<Node>
expandableContent
A property that represents the dialog expandable content area.BooleanProperty
expanded
Represents whether the dialogPane is expanded.ObjectProperty<Node>
graphic
The dialog graphic, presented either in the header, if one is showing, or to the left of thecontent
.ObjectProperty<Node>
header
Property representing the header area of the dialog pane.StringProperty
headerText
A property representing the header text for the dialog pane.-
Properties inherited from class javafx.scene.layout.Region
background, border, cacheShape, centerShape, height, insets, maxHeight, maxWidth, minHeight, minWidth, opaqueInsets, padding, prefHeight, prefWidth, scaleShape, shape, snapToPixel, width
-
Properties inherited from class javafx.scene.Parent
needsLayout
-
Properties inherited from class javafx.scene.Node
accessibleHelp, 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.Region
USE_COMPUTED_SIZE, USE_PREF_SIZE
-
Fields inherited from class javafx.scene.Node
BASELINE_OFFSET_SAME_AS_HEIGHT
-
-
Constructor Summary
Constructors Constructor Description DialogPane()
Creates a new DialogPane instance with a style class of 'dialog-pane'.
-
Method Summary
Modifier and Type Method Description protected double
computeMinHeight(double width)
Computes the minimum height of this region.protected double
computeMinWidth(double height)
Computes the minimum width of this region.protected 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.protected double
computePrefWidth(double height)
Computes the preferred width of this region for the given height.ObjectProperty<Node>
contentProperty()
Property representing the content area of the dialog.StringProperty
contentTextProperty()
A property representing the content text for the dialog pane.protected Node
createButton(ButtonType buttonType)
This method can be overridden by subclasses to create a custom button that will subsequently inserted into the DialogPane button area (created via thecreateButtonBar()
method, but mostly commonly it is an instance ofButtonBar
.protected Node
createButtonBar()
This method can be overridden by subclasses to provide the button bar.protected Node
createDetailsButton()
This method can be overridden by subclasses to create a custom details button.ObjectProperty<Node>
expandableContentProperty()
A property that represents the dialog expandable content area.BooleanProperty
expandedProperty()
Represents whether the dialogPane is expanded.ObservableList<ButtonType>
getButtonTypes()
Observable list of button types used for the dialog button bar area (created via thecreateButtonBar()
method).static List<CssMetaData<? extends Styleable,?>>
getClassCssMetaData()
Node
getContent()
Returns the dialog content as a Node (even if it was set as a String usingsetContentText(String)
- this was simply transformed into aNode
(most probably aLabel
).String
getContentText()
Returns the currently-set content text for this DialogPane.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.Node
getExpandableContent()
Returns the dialog expandable content node, if one is set, or null otherwise.Node
getGraphic()
Gets the value of the property graphic.Node
getHeader()
Node which acts as the dialog pane header.String
getHeaderText()
Returns the currently-set header text for this DialogPane.ObjectProperty<Node>
graphicProperty()
The dialog graphic, presented either in the header, if one is showing, or to the left of thecontent
.ObjectProperty<Node>
headerProperty()
Property representing the header area of the dialog pane.StringProperty
headerTextProperty()
A property representing the header text for the dialog pane.boolean
isExpanded()
Returns whether or not the dialogPane is expanded.protected void
layoutChildren()
Invoked during the layout pass to layout the children in thisParent
.Node
lookupButton(ButtonType buttonType)
This method provides a way in which developers may retrieve the actual Node for a givenButtonType
(assuming it is part of thebutton types
list).void
setContent(Node content)
Assign dialog content.void
setContentText(String contentText)
Sets the string to show in the dialog content area.void
setExpandableContent(Node content)
Sets the dialog expandable content node, or null if no expandable content needs to be shown.void
setExpanded(boolean value)
Sets whether the dialogPane is expanded.void
setGraphic(Node graphic)
Sets the dialog graphic, which will be displayed either in the header, if one is showing, or to the left of thecontent
.void
setHeader(Node header)
Assigns the dialog pane header.void
setHeaderText(String headerText)
Sets the string to show in the dialog header area.-
Methods inherited from class javafx.scene.layout.Pane
getChildren
-
Methods inherited from class javafx.scene.layout.Region
backgroundProperty, borderProperty, cacheShapeProperty, centerShapeProperty, computeMaxHeight, computeMaxWidth, getBackground, getBorder, getHeight, getInsets, getMaxHeight, getMaxWidth, getMinHeight, getMinWidth, getOpaqueInsets, getPadding, getPrefHeight, getPrefWidth, getShape, getUserAgentStylesheet, getWidth, heightProperty, insetsProperty, isCacheShape, isCenterShape, isResizable, 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.Parent
getBaselineOffset, getChildrenUnmodifiable, getManagedChildren, getStylesheets, isNeedsLayout, layout, lookup, needsLayoutProperty, queryAccessibleAttribute, requestLayout, requestParentLayout, setNeedsLayout, updateBounds
-
Methods inherited from class javafx.scene.Node
accessibleHelpProperty, accessibleRoleDescriptionProperty, accessibleRoleProperty, accessibleTextProperty, addEventFilter, addEventHandler, applyCss, autosize, blendModeProperty, boundsInLocalProperty, boundsInParentProperty, buildEventDispatchChain, cacheHintProperty, cacheProperty, clipProperty, computeAreaInScreen, contains, contains, cursorProperty, depthTestProperty, disabledProperty, disableProperty, effectiveNodeOrientationProperty, effectProperty, eventDispatcherProperty, executeAccessibleAction, fireEvent, focusedProperty, focusTraversableProperty, getAccessibleHelp, getAccessibleRole, getAccessibleRoleDescription, getAccessibleText, getBlendMode, getBoundsInLocal, getBoundsInParent, getCacheHint, getClip, getContentBias, getCursor, getDepthTest, getEffect, getEffectiveNodeOrientation, getEventDispatcher, getId, getInitialCursor, getInitialFocusTraversable, 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.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface javafx.css.Styleable
getStyleableNode
-
-
-
-
Property Detail
-
graphic
public final ObjectProperty<Node> graphicProperty
The dialog graphic, presented either in the header, if one is showing, or to the left of thecontent
.- See Also:
getGraphic()
,setGraphic(Node)
-
header
public final ObjectProperty<Node> headerProperty
Property representing the header area of the dialog pane. Note that if this header is set to a non-null value, that it will take up the entire top area of the DialogPane. It will also result in the DialogPane switching its layout to the 'header' layout - as outlined in theDialogPane
class javadoc.- See Also:
getHeader()
,setHeader(Node)
-
headerText
public final StringProperty headerTextProperty
A property representing the header text for the dialog pane. The header text is lower precedence than theheader node
, meaning that if both the header node and the headerText properties are set, the header text will not be displayed in a default DialogPane instance.When headerText is set to a non-null value, this will result in the DialogPane switching its layout to the 'header' layout - as outlined in the
DialogPane
class javadoc.- See Also:
getHeaderText()
,setHeaderText(String)
-
content
public final ObjectProperty<Node> contentProperty
Property representing the content area of the dialog.- See Also:
getContent()
,setContent(Node)
-
contentText
public final StringProperty contentTextProperty
A property representing the content text for the dialog pane. The content text is lower precedence than thecontent node
, meaning that if both the content node and the contentText properties are set, the content text will not be displayed in a default DialogPane instance.- See Also:
getContentText()
,setContentText(String)
-
expandableContent
public final ObjectProperty<Node> expandableContentProperty
A property that represents the dialog expandable content area. Any Node can be placed in this area, but it will only be shown when the user clicks the 'Show Details' expandable button. This button will be added automatically when the expandable content property is non-null.- See Also:
getExpandableContent()
,setExpandableContent(Node)
-
expanded
public final BooleanProperty expandedProperty
Represents whether the dialogPane is expanded.- See Also:
isExpanded()
,setExpanded(boolean)
-
-
Method Detail
-
graphicProperty
public final ObjectProperty<Node> graphicProperty()
The dialog graphic, presented either in the header, if one is showing, or to the left of thecontent
.- See Also:
getGraphic()
,setGraphic(Node)
-
getGraphic
public final Node getGraphic()
Gets the value of the property graphic.- Property description:
- The dialog graphic, presented either in the header, if one is showing, or
to the left of the
content
.
-
setGraphic
public final void setGraphic(Node graphic)
Sets the dialog graphic, which will be displayed either in the header, if one is showing, or to the left of thecontent
.- Parameters:
graphic
- The new dialog graphic, or null if no graphic should be shown.
-
getHeader
public final Node getHeader()
Node which acts as the dialog pane header.- Returns:
- the header of the dialog pane.
-
setHeader
public final void setHeader(Node header)
Assigns the dialog pane header. Any Node can be used.- Parameters:
header
- The new header of the DialogPane.
-
headerProperty
public final ObjectProperty<Node> headerProperty()
Property representing the header area of the dialog pane. Note that if this header is set to a non-null value, that it will take up the entire top area of the DialogPane. It will also result in the DialogPane switching its layout to the 'header' layout - as outlined in theDialogPane
class javadoc.- See Also:
getHeader()
,setHeader(Node)
-
setHeaderText
public final void setHeaderText(String headerText)
Sets the string to show in the dialog header area. Note that the header text is lower precedence than theheader node
, meaning that if both the header node and the headerText properties are set, the header text will not be displayed in a default DialogPane instance.When headerText is set to a non-null value, this will result in the DialogPane switching its layout to the 'header' layout - as outlined in the
DialogPane
class javadoc.- Parameters:
headerText
- the string to show in the dialog header area
-
getHeaderText
public final String getHeaderText()
Returns the currently-set header text for this DialogPane.- Returns:
- the currently-set header text for this DialogPane
-
headerTextProperty
public final StringProperty headerTextProperty()
A property representing the header text for the dialog pane. The header text is lower precedence than theheader node
, meaning that if both the header node and the headerText properties are set, the header text will not be displayed in a default DialogPane instance.When headerText is set to a non-null value, this will result in the DialogPane switching its layout to the 'header' layout - as outlined in the
DialogPane
class javadoc.- See Also:
getHeaderText()
,setHeaderText(String)
-
getContent
public final Node getContent()
Returns the dialog content as a Node (even if it was set as a String usingsetContentText(String)
- this was simply transformed into aNode
(most probably aLabel
).- Returns:
- dialog's content
-
setContent
public final void setContent(Node content)
Assign dialog content. Any Node can be used- Parameters:
content
- dialog's content
-
contentProperty
public final ObjectProperty<Node> contentProperty()
Property representing the content area of the dialog.- See Also:
getContent()
,setContent(Node)
-
setContentText
public final void setContentText(String contentText)
Sets the string to show in the dialog content area. Note that the content text is lower precedence than thecontent node
, meaning that if both the content node and the contentText properties are set, the content text will not be displayed in a default DialogPane instance.- Parameters:
contentText
- the string to show in the dialog content area
-
getContentText
public final String getContentText()
Returns the currently-set content text for this DialogPane.- Returns:
- the currently-set content text for this DialogPane
-
contentTextProperty
public final StringProperty contentTextProperty()
A property representing the content text for the dialog pane. The content text is lower precedence than thecontent node
, meaning that if both the content node and the contentText properties are set, the content text will not be displayed in a default DialogPane instance.- See Also:
getContentText()
,setContentText(String)
-
expandableContentProperty
public final ObjectProperty<Node> expandableContentProperty()
A property that represents the dialog expandable content area. Any Node can be placed in this area, but it will only be shown when the user clicks the 'Show Details' expandable button. This button will be added automatically when the expandable content property is non-null.- See Also:
getExpandableContent()
,setExpandableContent(Node)
-
getExpandableContent
public final Node getExpandableContent()
Returns the dialog expandable content node, if one is set, or null otherwise.- Returns:
- the dialog expandable content node
-
setExpandableContent
public final void setExpandableContent(Node content)
Sets the dialog expandable content node, or null if no expandable content needs to be shown.- Parameters:
content
- the dialog expandable content node
-
expandedProperty
public final BooleanProperty expandedProperty()
Represents whether the dialogPane is expanded.- See Also:
isExpanded()
,setExpanded(boolean)
-
isExpanded
public final boolean isExpanded()
Returns whether or not the dialogPane is expanded.- Returns:
- true if dialogPane is expanded.
-
setExpanded
public final void setExpanded(boolean value)
Sets whether the dialogPane is expanded. This only makes sense when there isexpandable content
to show.- Parameters:
value
- true if dialogPane should be expanded.
-
getButtonTypes
public final ObservableList<ButtonType> getButtonTypes()
Observable list of button types used for the dialog button bar area (created via thecreateButtonBar()
method). Modifying the contents of this list will immediately change the buttons displayed to the user within the dialog pane.- Returns:
- The
ObservableList
ofbutton types
available to the user.
-
lookupButton
public final Node lookupButton(ButtonType buttonType)
This method provides a way in which developers may retrieve the actual Node for a givenButtonType
(assuming it is part of thebutton types
list).- Parameters:
buttonType
- TheButtonType
for which a Node representation is requested.- Returns:
- The Node used to represent the button type, as created by
createButton(ButtonType)
, and only if the button type is part of thebutton types
list, otherwise null.
-
createButtonBar
protected Node createButtonBar()
This method can be overridden by subclasses to provide the button bar. Note that by overriding this method, the developer must take on multiple responsibilities:- The developer must immediately iterate through all
button types
and callcreateButton(ButtonType)
for each of them in turn. - The developer must add a listener to the
button types
list, and when this list changes update the button bar as appropriate. - Similarly, the developer must watch for changes to the
expandable content
property, adding and removing the details button (created viacreateDetailsButton()
method).
The default implementation of this method creates and returns a new
ButtonBar
instance.- Returns:
- the created button bar
- The developer must immediately iterate through all
-
createButton
protected Node createButton(ButtonType buttonType)
This method can be overridden by subclasses to create a custom button that will subsequently inserted into the DialogPane button area (created via thecreateButtonBar()
method, but mostly commonly it is an instance ofButtonBar
.- Parameters:
buttonType
- TheButtonType
to create a button from.- Returns:
- A JavaFX
Node
that represents the givenButtonType
, most commonly an instance ofButton
.
-
createDetailsButton
protected Node createDetailsButton()
This method can be overridden by subclasses to create a custom details button.To override this method you must do two things:
- The button will need to have its own code set to handle mouse / keyboard
interaction and to toggle the state of the
expanded
property. - If your button changes its visuals based on whether the dialog pane
is expanded or collapsed, you should add a listener to the
expanded
property, so that you may update the button visuals.
- Returns:
- the created details button
- The button will need to have its own code set to handle mouse / keyboard
interaction and to toggle the state of the
-
layoutChildren
protected 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:
layoutChildren
in classParent
-
computeMinWidth
protected double computeMinWidth(double height)
Computes the minimum width of this region. Returns the sum of the left and right insets by default. 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:
computeMinWidth
in classRegion
- Parameters:
height
- the height that should be used if min width depends on it- Returns:
- the computed minimum width of this region
-
computeMinHeight
protected double computeMinHeight(double width)
Computes the minimum height of this region. Returns the sum of the top and bottom insets by default. 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:
computeMinHeight
in classRegion
- Parameters:
width
- the width that should be used if min height depends on it- Returns:
- the computed minimum height for this region
-
computePrefWidth
protected 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:
computePrefWidth
in classRegion
- Parameters:
height
- the height that should be used if preferred width depends on it- Returns:
- the computed preferred width for this region
-
computePrefHeight
protected 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:
computePrefHeight
in classRegion
- Parameters:
width
- the width that should be used if preferred height depends on it- Returns:
- the computed preferred height for this region
-
getClassCssMetaData
public static List<CssMetaData<? extends Styleable,?>> getClassCssMetaData()
- Returns:
- The CssMetaData associated with this class, which may include the CssMetaData of its superclasses.
-
getCssMetaData
public 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.- Specified by:
getCssMetaData
in interfaceStyleable
- Overrides:
getCssMetaData
in classRegion
- Returns:
- The CssMetaData associated with this node, which may include the CssMetaData of its superclasses.
-
-