Class VBox
- All Implemented Interfaces:
 LayoutMeasurable,LayoutMeasurableMixin,HasBackgroundProperty,HasBlendModeProperty,HasBorderProperty,HasClipProperty,HasEffectProperty,HasHeightProperty,HasLayoutXProperty,HasLayoutYProperty,HasManagedProperty,HasMaxHeightProperty,HasMaxWidthProperty,HasMinHeightProperty,HasMinWidthProperty,HasMouseTransparentProperty,HasOnMouseClickedProperty,HasOpacityProperty,HasPaddingProperty,HasParentProperty,HasPrefHeightProperty,HasPrefWidthProperty,HasSnapToPixelProperty,HasVisibleProperty,HasWidthProperty,Styleable,EventTarget,INode,PreferenceResizableNode
- Direct Known Subclasses:
 TextFlow
VBox example:
     VBox vbox = new VBox(8); // spacing = 8
     vbox.getChildren().addAll(new Button("Cut"), new Button("Copy"), new Button("Paste"));
 
 VBox will resize children (if resizable) to their preferred heights and uses its
 fillWidth property to determine whether to resize their widths to
 fill its own width or keep their widths to their preferred (fillWidth defaults to true).
 The alignment of the content is controlled by the alignment property,
 which defaults to Pos.TOP_LEFT.
 If a vbox is resized larger than its preferred height, by default it will keep children to their preferred heights, leaving the extra space unused. If an application wishes to have one or more children be allocated that extra space it may optionally set a vgrow constraint on the child. See "Optional Layout Constraints" for details.
VBox lays out each managed child regardless of the child's visible property value; unmanaged children are ignored.
Resizable Range
A vbox's parent will resize the vbox within the vbox's resizable range during layout. By default the vbox computes this range based on its content as outlined in the table below.
| width | height | |
|---|---|---|
| minimum | left/right insets plus the largest of the children's min widths. | top/bottom insets plus the sum of each child's min height plus spacing between each child. | 
| preferred | left/right insets plus the largest of the children's pref widths. | top/bottom insets plus the sum of each child's pref height plus spacing between each child. | 
| maximum | Double.MAX_VALUE | Double.MAX_VALUE | 
A vbox's unbounded maximum width and height are an indication to the parent that it may be resized beyond its preferred size to fill whatever space is assigned to it.
VBox provides properties for setting the size range directly. These properties default to the sentinel value USE_COMPUTED_SIZE, however the application may set them to other values as needed:
     vbox.setPrefWidth(400);
 
 Applications may restore the computed values by setting these properties back
 to USE_COMPUTED_SIZE.
 VBox does not clip its content by default, so it is possible that children's bounds may extend outside its own bounds if a child's min size prevents it from being fit within the vbox.
Optional Layout Constraints
An application may set constraints on individual children to customize VBox's layout. For each constraint, VBox provides a static method for setting it on the child.
| Constraint | Type | Description | 
|---|---|---|
| vgrow | javafx.scene.layout.Priority | The vertical grow priority for the child. | 
| margin | javafx.geometry.Insets | Margin space around the outside of the child. | 
For example, if a vbox needs the ListView to be allocated all extra space:
     VBox vbox = new VBox();
     ListView list = new ListView();
     VBox.setVgrow(list, Priority.ALWAYS);
     vbox.getChildren().addAll(new Label("Names:"), list);
 
 If more than one child has the same grow priority set, then the vbox will
 allocate equal amounts of space to each.  VBox will only grow a child up to
 its maximum height, so if the child has a max height other than Double.MAX_VALUE,
 the application may need to override the max to allow it to grow.- Since:
 - JavaFX 2.0
 
- 
Property Summary
PropertiesTypePropertyDescriptionfinal ObjectProperty<Pos>The overall alignment of children within the vbox's width and height.final BooleanPropertyWhether or not resizable children will be resized to fill the full width of the vbox or be resized to their preferred width and aligned according to thealignmenthpos value.final DoublePropertyThe amount of vertical space between each child in the vbox.Properties inherited from class javafx.scene.layout.Region
background, border, height, insets, maxHeight, maxWidth, minHeight, minWidth, padding, prefHeight, prefWidth, snapToPixel, widthProperties inherited from class javafx.scene.Parent
needsLayoutProperties inherited from class javafx.scene.Node
blendMode, cacheHint, cache, clip, cursor, disabled, disable, effect, eventDispatcher, focused, focusTraversable, hover, id, layoutBounds, layoutX, layoutY, managed, mouseTransparent, onContextMenuRequested, onDragDetected, onDragDone, onDragDropped, onDragEntered, onDragExited, onDragOver, onKeyPressed, onKeyReleased, onKeyTyped, onMouseClicked, onMouseDragged, onMouseEntered, onMouseExited, onMouseMoved, onMousePressed, onMouseReleased, onScroll, onSwipeDown, onSwipeLeft, onSwipeRight, onSwipeUp, onTouchMoved, onTouchPressed, onTouchReleased, onTouchStationary, opacity, parent, pressed, rotate, scaleX, scaleY, scaleZ, scene, style, translateX, translateY, visibleProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasBlendModeProperty
blendModeProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasClipProperty
clipProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasEffectProperty
effectProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasLayoutXProperty
layoutXProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasLayoutYProperty
layoutYProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasManagedProperty
managedProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasMouseTransparentProperty
mouseTransparentProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasOnMouseClickedProperty
onMouseClickedProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasOpacityProperty
opacityProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasParentProperty
parentProperties inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasVisibleProperty
visible - 
Field Summary
Fields inherited from interface javafx.scene.INode
BASELINE_OFFSET_SAME_AS_HEIGHTFields inherited from interface javafx.scene.layout.PreferenceResizableNode
USE_COMPUTED_SIZE, USE_PREF_SIZE - 
Constructor Summary
Constructors - 
Method Summary
Modifier and TypeMethodDescriptionfinal ObjectProperty<Pos>The overall alignment of children within the vbox's width and height.static voidclearConstraints(Node child) Removes all vbox constraints from the child node.protected doublecomputeMinHeight(double width) Computes the minimum height of this region.protected doublecomputeMinWidth(double height) Computes the minimum width of this region.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.final BooleanPropertyWhether or not resizable children will be resized to fill the full width of the vbox or be resized to their preferred width and aligned according to thealignmenthpos value.final PosGets the value of thealignmentproperty.static InsetsReturns the child's margin property if set.final doubleGets the value of thespacingproperty.static PriorityReturns the child's vgrow property if set.final booleanGets the value of thefillWidthproperty.protected voidInvoked during the layout pass to layout the children in thisParent.voidRequests a layout pass to be performed before the next scene is rendered.final voidsetAlignment(Pos value) Sets the value of thealignmentproperty.final voidsetFillWidth(boolean value) Sets the value of thefillWidthproperty.static voidSets the margin for the child when contained by a vbox.final voidsetSpacing(double value) Sets the value of thespacingproperty.static voidSets the vertical grow priority for the child when contained by a vbox.final DoublePropertyThe amount of vertical space between each child in the vbox.Methods inherited from class javafx.scene.layout.Region
backgroundProperty, borderProperty, boundedSize, computeMaxHeight, computeMaxWidth, getInsets, heightProperty, impl_computeGeomBounds, impl_computeLayoutBounds, impl_maxHeight, impl_maxWidth, impl_minHeight, impl_minWidth, impl_prefHeight, impl_prefWidth, insetsProperty, layoutInArea, layoutInArea, layoutInArea, layoutInArea, maxHeightProperty, maxWidthProperty, minHeightProperty, minWidthProperty, paddingProperty, positionInArea, positionInArea, prefHeightProperty, prefWidthProperty, resize, setMaxSize, setMinSize, setPrefSize, snappedBottomInset, snappedLeftInset, snappedRightInset, snappedTopInset, snapPosition, snapPositionX, snapPositionY, snapSize, snapSizeX, snapSizeY, snapSpace, snapSpaceX, snapSpaceY, snapToPixelProperty, widthPropertyMethods inherited from class javafx.scene.Parent
getBaselineOffset, getChildren, getChildrenUnmodifiable, getManagedChildren, isNeedsLayout, layout, needsLayoutProperty, requestParentLayout, setLayoutFlag, setNeedsLayout, setSceneRootMethods inherited from class javafx.scene.Node
addEventFilter, addEventHandler, autosize, blendModeProperty, buildEventDispatchChain, cacheHintProperty, cacheProperty, clipProperty, createLayoutMeasurable, cursorProperty, disabledProperty, disableProperty, effectProperty, eventDispatcherProperty, fireEvent, focusedProperty, focusTraversableProperty, getAllNodeTransforms, getBoundsInLocal, getCacheHint, getCursor, getEventDispatcher, getId, getLayoutMeasurable, getNodePeer, getOnContextMenuRequested, getOnDragDetected, getOnDragDone, getOnDragDropped, getOnDragEntered, getOnDragExited, getOnDragOver, getOnKeyPressed, getOnKeyReleased, getOnKeyTyped, getOnMouseDragged, getOnMouseEntered, getOnMouseExited, getOnMouseMoved, getOnMousePressed, getOnMouseReleased, getOnScroll, getOnSwipeDown, getOnSwipeLeft, getOnSwipeRight, getOnSwipeUp, getOnTouchMoved, getOnTouchPressed, getOnTouchReleased, getOnTouchStationary, getOrCreateAndBindNodePeer, getProperties, getRotate, getScaleX, getScaleY, getScaleZ, getScene, getStyle, getStyleClass, getTransforms, getTranslateX, getTranslateY, getUserData, hasProperties, hoverProperty, idProperty, impl_getLayoutBounds, impl_isTreeVisible, impl_traverse, isCache, isDisable, isDisabled, isFocused, isFocusTraversable, isHover, isPressed, layoutBoundsProperty, layoutXProperty, layoutYProperty, localToParent, localToParent, localToParent, localToScene, localToScene, localToScreen, localToScreen, localToScreen, localToScreen, managedProperty, mouseTransparentProperty, onContextMenuRequestedProperty, onDragDetectedProperty, onDragDoneProperty, onDragDroppedProperty, onDragEnteredProperty, onDragExitedProperty, onDragOverProperty, onKeyPressedProperty, onKeyReleasedProperty, onKeyTypedProperty, onMouseClickedProperty, onMouseDraggedProperty, onMouseEnteredProperty, onMouseExitedProperty, onMouseMovedProperty, onMousePressedProperty, onMouseReleasedProperty, onNodePeerReady, onPeerSizeChanged, onScrollProperty, onSwipeDownProperty, onSwipeLeftProperty, onSwipeRightProperty, onSwipeUpProperty, onTouchMovedProperty, onTouchPressedProperty, onTouchReleasedProperty, onTouchStationaryProperty, opacityProperty, parentProperty, parentToLocal, pressedProperty, removeEventFilter, removeEventHandler, requestFocus, requestPeerFocus, rotateProperty, scaleXProperty, scaleYProperty, scaleZProperty, sceneProperty, sceneToLocal, sceneToLocal, sceneToLocal, setCache, setCacheHint, setCursor, setDisable, setDisabled, setEventDispatcher, setEventHandler, setFocused, setFocusTraversable, setHover, setId, setNodePeer, setOnContextMenuRequested, setOnDragDetected, setOnDragDone, setOnDragDropped, setOnDragEntered, setOnDragExited, setOnDragOver, setOnKeyPressed, setOnKeyReleased, setOnKeyTyped, setOnMouseDragged, setOnMouseEntered, setOnMouseExited, setOnMouseMoved, setOnMousePressed, setOnMouseReleased, setOnScroll, setOnSwipeDown, setOnSwipeLeft, setOnSwipeRight, setOnSwipeUp, setOnTouchMoved, setOnTouchPressed, setOnTouchReleased, setOnTouchStationary, setPressed, setRotate, setScaleX, setScaleY, setScaleZ, setScene, setStyle, setTranslateX, setTranslateY, setUserData, shouldUseLayoutMeasurable, snapshot, startDragAndDrop, styleProperty, toBack, toFront, translateXProperty, translateYProperty, visiblePropertyMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasBackgroundProperty
getBackground, setBackgroundMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasBlendModeProperty
blendModeProperty, getBlendMode, setBlendModeMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasBorderProperty
getBorder, setBorderMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasClipProperty
clipProperty, getClip, setClipMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasEffectProperty
effectProperty, getEffect, setEffectMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasHeightProperty
getHeight, setHeightMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasLayoutXProperty
getLayoutX, layoutXProperty, setLayoutXMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasLayoutYProperty
getLayoutY, layoutYProperty, setLayoutYMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasManagedProperty
isManaged, managedProperty, setManagedMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasMaxHeightProperty
getMaxHeight, setMaxHeightMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasMaxWidthProperty
getMaxWidth, setMaxWidthMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasMinHeightProperty
getMinHeight, setMinHeightMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasMinWidthProperty
getMinWidth, setMinWidthMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasMouseTransparentProperty
isMouseTransparent, mouseTransparentProperty, setMouseTransparentMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasOnMouseClickedProperty
getOnMouseClicked, onMouseClickedProperty, setOnMouseClickedMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasOpacityProperty
getOpacity, opacityProperty, setOpacityMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasPaddingProperty
getPadding, setPaddingMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasParentProperty
getParent, parentProperty, setParentMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasPrefHeightProperty
getPrefHeight, setPrefHeightMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasPrefWidthProperty
getPrefWidth, setPrefWidthMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasSnapToPixelProperty
isSnapToPixel, setSnapToPixelMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasVisibleProperty
isVisible, setVisible, visiblePropertyMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.markers.HasWidthProperty
getWidth, setWidthMethods inherited from interface javafx.scene.INode
autosize, getAllNodeTransforms, getBaselineOffset, getNodePeer, getOrCreateAndBindNodePeer, getProperties, getScene, getTransforms, hasProperties, relocate, resizeRelocateMethods inherited from interface dev.webfx.kit.mapper.peers.javafxgraphics.emul_coupling.LayoutMeasurableMixin
clearCache, getLayoutBounds, getLayoutMeasurable, maxHeight, maxWidth, minHeight, minWidth, prefHeight, prefWidthMethods inherited from interface javafx.scene.layout.PreferenceResizableNode
isResizable 
- 
Property Details
- 
spacing
The amount of vertical space between each child in the vbox.- See Also:
 
 - 
alignment
The overall alignment of children within the vbox's width and height. - 
fillWidth
Whether or not resizable children will be resized to fill the full width of the vbox or be resized to their preferred width and aligned according to thealignmenthpos value. 
 - 
 - 
Constructor Details
- 
VBox
public VBox()Creates aVBoxlayout withspacing = 0and alignment atTOP_LEFT. - 
VBox
public VBox(double spacing) Creates aVBoxlayout with the specified spacing between children.- Parameters:
 spacing- the amount of vertical space between each child
 - 
VBox
Creates aVBoxlayout withspacing = 0.- Parameters:
 children- the initial set of children for this pane- Since:
 - JavaFX 8.0
 
 - 
VBox
Creates aVBoxlayout with the specified spacing between children.- Parameters:
 spacing- the amount of vertical space between each childchildren- the initial set of children for this pane- Since:
 - JavaFX 8.0
 
 
 - 
 - 
Method Details
- 
setVgrow
Sets the vertical grow priority for the child when contained by a vbox. If set, the vbox will use the priority value to allocate additional space if the vbox is resized larger than its preferred height. If multiple vbox children have the same vertical grow priority, then the extra space will be split evenly between them. If no vertical grow priority is set on a child, the vbox will never allocate any additional vertical space for that child.Setting the value to
nullwill remove the constraint.- Parameters:
 child- the child of a vboxvalue- the vertical grow priority for the child
 - 
getVgrow
Returns the child's vgrow property if set.- Parameters:
 child- the child node of a vbox- Returns:
 - the vertical grow priority for the child or null if no priority was set
 
 - 
setMargin
Sets the margin for the child when contained by a vbox. If set, the vbox will layout the child so that it has the margin space around it. Setting the value to null will remove the constraint.- Parameters:
 child- the child mode of a vboxvalue- the margin of space around the child
 - 
getMargin
Returns the child's margin property if set.- Parameters:
 child- the child node of a vbox- Returns:
 - the margin for the child or null if no margin was set
 
 - 
clearConstraints
Removes all vbox constraints from the child node.- Parameters:
 child- the child node
 - 
spacingProperty
The amount of vertical space between each child in the vbox.- Returns:
 - the amount of vertical space between each child in the vbox
 - See Also:
 
 - 
setSpacing
public final void setSpacing(double value) Sets the value of thespacingproperty.- Property description:
 - The amount of vertical space between each child in the vbox.
 - Parameters:
 value- the value for thespacingproperty- See Also:
 
 - 
getSpacing
public final double getSpacing()Gets the value of thespacingproperty.- Property description:
 - The amount of vertical space between each child in the vbox.
 - Returns:
 - the value of the 
spacingproperty - See Also:
 
 - 
alignmentProperty
The overall alignment of children within the vbox's width and height.- Returns:
 - the overall alignment of children within the vbox's width and height
 - See Also:
 
 - 
setAlignment
Sets the value of thealignmentproperty.- Property description:
 - The overall alignment of children within the vbox's width and height.
 - Parameters:
 value- the value for thealignmentproperty- See Also:
 
 - 
getAlignment
Gets the value of thealignmentproperty.- Property description:
 - The overall alignment of children within the vbox's width and height.
 - Returns:
 - the value of the 
alignmentproperty - See Also:
 
 - 
fillWidthProperty
Whether or not resizable children will be resized to fill the full width of the vbox or be resized to their preferred width and aligned according to thealignmenthpos value.- Returns:
 - true if resizable children will be resized to fill the full width of the vbox
 - See Also:
 
 - 
setFillWidth
public final void setFillWidth(boolean value) Sets the value of thefillWidthproperty.- Property description:
 - Whether or not resizable children will be resized to fill the full width of the vbox
 or be resized to their preferred width and aligned according to the 
alignmenthpos value. - Parameters:
 value- the value for thefillWidthproperty- See Also:
 
 - 
isFillWidth
public final boolean isFillWidth()Gets the value of thefillWidthproperty.- Property description:
 - Whether or not resizable children will be resized to fill the full width of the vbox
 or be resized to their preferred width and aligned according to the 
alignmenthpos value. - Returns:
 - the value of the 
fillWidthproperty - See Also:
 
 - 
getContentBias
- Returns:
 - null unless one of its children has a content bias.
 
 - 
computeMinWidth
protected double computeMinWidth(double height) Description copied from class:RegionComputes 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:
 computeMinWidthin 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) Description copied from class:RegionComputes 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:
 computeMinHeightin 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) Description copied from class:RegionComputes 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 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) Description copied from class:RegionComputes 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 classRegion- Parameters:
 width- the width that should be used if preferred height depends on it- Returns:
 - the computed preferred height for this region
 
 - 
requestLayout
public void requestLayout()Description copied from class:ParentRequests a layout pass to be performed before the next scene is rendered. This is batched up asynchronously to happen once per "pulse", or frame of animation.If this parent is either a layout root or unmanaged, then it will be added directly to the scene's dirty layout list, otherwise requestParentLayout will be invoked.
- Overrides:
 requestLayoutin classParent
 - 
layoutChildren
protected void layoutChildren()Description copied from class:ParentInvoked 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 classParent
 
 -