Spec-Zone .ru
спецификации, руководства, описания, API
|
T
- The type of the elements contained within the TreeView TreeItem
instances.public class CheckBoxTreeCell<T> extends TreeCell<T>
TreeCell
implementation that draws a
CheckBox
node inside the cell, along with support for common
interactions (discussed in more depth shortly).
To make creating TreeViews with CheckBoxes easier, a convenience class
called CheckBoxTreeItem
is provided. It is highly recommended
that developers use this class, rather than the regular TreeItem
class, when constructing their TreeView tree structures. Refer to the
CheckBoxTreeItem API documentation for an example on how these two classes
can be combined.
When used in a TreeView, the CheckBoxCell is rendered with a CheckBox to
the right of the 'disclosure node' (i.e. the arrow). The item stored in
TreeItem.getValue()
will then have the StringConverter called
on it, and this text will take all remaining horizontal space. Additionally,
by using CheckBoxTreeItem
, the TreeView will automatically handle
situations such as:
CheckBox
beside an item that has children will
result in all children also becoming selected/unselected.
CheckBox
beside an item that has a parent will
possibly toggle the state of the parent. For example, if you select a
single child, the parent will become indeterminate (indicating partial
selection of children). If you proceed to select all children, the
parent will then show that it too is selected. This is recursive, with
all parent nodes updating as expected.
CheckBoxTreeItem
is not desirable,
then it is necessary to call one of the constructors where a Callback
is provided that can return an ObservableValue<Boolean>
given a TreeItem
instance. This ObservableValue<Boolean>
should represent the boolean state of the given TreeItem
.Type | Property and Description |
---|---|
ObjectProperty<StringConverter<TreeItem<T>>> |
converter
The
StringConverter property. |
ObjectProperty<Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>>> |
selectedStateCallback
Property representing the
Callback that is bound to by the
CheckBox shown on screen. |
disclosureNode, treeItem, treeView
index
alignment, contentDisplay, ellipsisString, font, graphic, graphicTextGap, labelPadding, mnemonicParsing, textAlignment, textFill, textOverrun, text, underline, wrapText
contextMenu, height, maxHeight, maxWidth, minHeight, minWidth, prefHeight, prefWidth, skinClassName, skin, tooltip, width
needsLayout
blendMode, boundsInLocal, boundsInParent, cacheHint, cache, clip, cursor, depthTest, disabled, disable, effect, eventDispatcher, focused, focusTraversable, hover, id, inputMethodRequests, layoutBounds, layoutX, layoutY, localToParentTransform, localToSceneTransform, managed, mouseTransparent, 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, visible
USE_COMPUTED_SIZE, USE_PREF_SIZE
Constructor and Description |
---|
CheckBoxTreeCell()
Creates a default
CheckBoxTreeCell that assumes the TreeView is
constructed with CheckBoxTreeItem instances, rather than the
default TreeItem . |
CheckBoxTreeCell(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty)
Creates a
CheckBoxTreeCell for use in a TreeView control via a
cell factory. |
CheckBoxTreeCell(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty,
StringConverter<TreeItem<T>> converter)
Creates a
CheckBoxTreeCell for use in a TreeView control via a
cell factory. |
Modifier and Type | Method and Description |
---|---|
ObjectProperty<StringConverter<TreeItem<T>>> |
converterProperty()
The
StringConverter property. |
static <T> Callback<TreeView<T>,TreeCell<T>> |
forTreeView()
Creates a cell factory for use in a TreeView control, although there is a
major assumption when used in a TreeView: this cell factory assumes that
the TreeView root, and all children are instances of
CheckBoxTreeItem , rather than the default TreeItem class
that is used normally. |
static <T> Callback<TreeView<T>,TreeCell<T>> |
forTreeView(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty)
Creates a cell factory for use in a TreeView control.
|
static <T> Callback<TreeView<T>,TreeCell<T>> |
forTreeView(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty,
StringConverter<TreeItem<T>> converter)
Creates a cell factory for use in a TreeView control.
|
StringConverter<TreeItem<T>> |
getConverter()
Returns the
StringConverter used in this cell. |
Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> |
getSelectedStateCallback()
Returns the
Callback that is bound to by the CheckBox shown on screen. |
ObjectProperty<Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>>> |
selectedStateCallbackProperty()
Property representing the
Callback that is bound to by the
CheckBox shown on screen. |
void |
setConverter(StringConverter<TreeItem<T>> value)
Sets the
StringConverter to be used in this cell. |
void |
setSelectedStateCallback(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> value)
Sets the
Callback that is bound to by the CheckBox shown on screen. |
void |
updateItem(T item,
boolean empty)
Updates the item associated with this Cell.
|
cancelEdit, commitEdit, disclosureNodeProperty, getDisclosureNode, getTreeItem, getTreeView, setDisclosureNode, startEdit, treeItemProperty, treeViewProperty, updateTreeItem, updateTreeView
getIndex, indexProperty, updateIndex
editableProperty, editingProperty, emptyProperty, getItem, isEditable, isEditing, isEmpty, isSelected, itemProperty, selectedProperty, setEditable, setItem, updateSelected
alignmentProperty, contentDisplayProperty, ellipsisStringProperty, fontProperty, getAlignment, getContentBias, getContentDisplay, getEllipsisString, getFont, getGraphic, getGraphicTextGap, getLabelPadding, getText, getTextAlignment, getTextFill, getTextOverrun, graphicProperty, graphicTextGapProperty, isMnemonicParsing, isUnderline, isWrapText, labelPaddingProperty, mnemonicParsingProperty, setAlignment, setContentDisplay, setEllipsisString, setFont, setGraphic, setGraphicTextGap, setMnemonicParsing, setText, setTextAlignment, setTextFill, setTextOverrun, setUnderline, setWrapText, textAlignmentProperty, textFillProperty, textOverrunProperty, textProperty, underlineProperty, wrapTextProperty
computeMaxHeight, computeMaxWidth, computeMinHeight, computeMinWidth, computePrefHeight, computePrefWidth, contextMenuProperty, getBaselineOffset, getContextMenu, getHeight, getMaxHeight, getMaxWidth, getMinHeight, getMinWidth, getPrefHeight, getPrefWidth, getSkin, getTooltip, getUserAgentStylesheet, getWidth, heightProperty, intersects, isResizable, layoutChildren, maxHeight, maxHeightProperty, maxWidth, maxWidthProperty, minHeight, minHeightProperty, minWidth, minWidthProperty, prefHeight, prefHeightProperty, prefWidth, prefWidthProperty, resize, setContextMenu, setHeight, setMaxHeight, setMaxSize, setMaxWidth, setMinHeight, setMinSize, setMinWidth, setPrefHeight, setPrefSize, setPrefWidth, setSkin, setSkinClassName, setTooltip, setWidth, skinClassNameProperty, skinProperty, tooltipProperty, widthProperty
getChildren, getChildrenUnmodifiable, getManagedChildren, getStylesheets, isNeedsLayout, layout, lookup, needsLayoutProperty, requestLayout, setNeedsLayout
addEventFilter, addEventHandler, autosize, blendModeProperty, boundsInLocalProperty, boundsInParentProperty, buildEventDispatchChain, cacheHintProperty, cacheProperty, clipProperty, contains, contains, cursorProperty, depthTestProperty, disabledProperty, disableProperty, effectProperty, eventDispatcherProperty, fireEvent, focusedProperty, focusTraversableProperty, getBlendMode, getBoundsInLocal, getBoundsInParent, getCacheHint, getClip, getCursor, getDepthTest, getEffect, getEventDispatcher, getId, getInputMethodRequests, getLayoutBounds, getLayoutX, getLayoutY, getLocalToParentTransform, getLocalToSceneTransform, 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, getRotate, getRotationAxis, getScaleX, getScaleY, getScaleZ, getScene, getStyle, getStyleClass, getTransforms, getTranslateX, getTranslateY, getTranslateZ, getUserData, hasProperties, hoverProperty, idProperty, inputMethodRequestsProperty, intersects, isCache, isDisable, isDisabled, isFocused, isFocusTraversable, isHover, isManaged, isMouseTransparent, isPickOnBounds, isPressed, isVisible, layoutBoundsProperty, layoutXProperty, layoutYProperty, localToParent, localToParent, localToParent, localToParentTransformProperty, localToScene, localToScene, localToScene, localToSceneTransformProperty, lookupAll, managedProperty, mouseTransparentProperty, 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, pickOnBoundsProperty, pressedProperty, relocate, removeEventFilter, removeEventHandler, requestFocus, resizeRelocate, rotateProperty, rotationAxisProperty, scaleXProperty, scaleYProperty, scaleZProperty, sceneProperty, sceneToLocal, sceneToLocal, sceneToLocal, setBlendMode, setCache, setCacheHint, setClip, setCursor, setDepthTest, setDisable, setDisabled, setEffect, setEventDispatcher, setEventHandler, setFocused, setFocusTraversable, setHover, setId, setInputMethodRequests, setLayoutX, setLayoutY, setManaged, setMouseTransparent, 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, setVisible, snapshot, snapshot, startDragAndDrop, startFullDrag, styleProperty, toBack, toFront, toString, translateXProperty, translateYProperty, translateZProperty, visibleProperty
public final ObjectProperty<StringConverter<TreeItem<T>>> converterProperty
StringConverter
property.getConverter()
,
setConverter(StringConverter)
public final ObjectProperty<Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>>> selectedStateCallbackProperty
Callback
that is bound to by the
CheckBox shown on screen.public CheckBoxTreeCell()
CheckBoxTreeCell
that assumes the TreeView is
constructed with CheckBoxTreeItem
instances, rather than the
default TreeItem
.
By using CheckBoxTreeItem
, it will internally manage the selected
and indeterminate state of each item in the tree.public CheckBoxTreeCell(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty)
CheckBoxTreeCell
for use in a TreeView control via a
cell factory. Unlike CheckBoxTreeCell()
, this
method does not assume that all TreeItem instances in the TreeView are
CheckBoxTreeItem
.
To call this method, it is necessary to provide a
If the items are not Callback
that, given an object of type TreeItemObservableValue<Boolean>
that represents whether the given
item is selected or not. This ObservableValue<Boolean>
will be
bound bidirectionally (meaning that the CheckBox in the cell will
set/unset this property based on user interactions, and the CheckBox will
reflect the state of the ObservableValue<Boolean>
, if it changes
externally).
CheckBoxTreeItem
instances, it becomes
the developers responsibility to handle updating the state of parent and
children TreeItems. This means that, given a TreeItem, this class will
simply toggles the ObservableValue<Boolean>
that is provided, and
no more. Of course, this functionality can then be implemented externally
by adding observers to the ObservableValue<Boolean>
, and toggling
the state of other properties as necessary.
getSelectedProperty
- A Callback
that will return an
ObservableValue<Boolean>
that represents whether the given
item is selected or not.public CheckBoxTreeCell(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty, StringConverter<TreeItem<T>> converter)
CheckBoxTreeCell
for use in a TreeView control via a
cell factory. Unlike CheckBoxTreeCell()
, this
method does not assume that all TreeItem instances in the TreeView are
CheckBoxTreeItem
.
To call this method, it is necessary to provide a If the items are not Callback
that, given an object of type TreeItemObservableValue<Boolean>
that represents whether the given item
is selected or not. This ObservableValue<Boolean>
will be bound
bidirectionally (meaning that the CheckBox in the cell will set/unset
this property based on user interactions, and the CheckBox will reflect
the state of the ObservableValue<Boolean>
, if it changes
externally).
CheckBoxTreeItem
instances, it becomes
the developers responsibility to handle updating the state of parent and
children TreeItems. This means that, given a TreeItem, this class will
simply toggles the ObservableValue<Boolean>
that is provided, and
no more. Of course, this functionality can then be implemented externally
by adding observers to the ObservableValue<Boolean>
, and toggling
the state of other properties as necessary.
getSelectedProperty
- A Callback
that will return an
ObservableValue<Boolean>
that represents whether the given
item is selected or not.converter
- A StringConverter that, give an object of type TreeItempublic static <T> Callback<TreeView<T>,TreeCell<T>> forTreeView()
CheckBoxTreeItem
, rather than the default TreeItem
class
that is used normally.
When used in a TreeView, the CheckBoxCell is rendered with a CheckBox
to the right of the 'disclosure node' (i.e. the arrow). The item stored
in TreeItem.getValue()
will then have the StringConverter
called on it, and this text will take all remaining horizontal space.
Additionally, by using CheckBoxTreeItem
, the TreeView will
automatically handle situations such as:
CheckBox
beside an item that has children
will result in all children also becoming selected/unselected.CheckBox
beside an item that has a parent
will possibly toggle the state of the parent. For example, if you
select a single child, the parent will become indeterminate (indicating
partial selection of children). If you proceed to select all
children, the parent will then show that it too is selected. This is
recursive, with all parent nodes updating as expected.Unfortunately, due to limitations in Java, it is necessary to provide an explicit cast when using this method. For example:
final TreeView<String> treeView = new TreeView<String>();
treeView.setCellFactory(CheckBoxCell.<String>forTreeView());
T
- The type of the elements contained within the
CheckBoxTreeItem
instances.Callback
that will return a TreeCell that is able to
work on the type of element contained within the TreeView root, and
all of its children (recursively).public static <T> Callback<TreeView<T>,TreeCell<T>> forTreeView(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty)
forTreeView()
, this method does not assume that all TreeItem
instances in the TreeView are CheckBoxTreeItem
instances.
When used in a TreeView, the CheckBoxCell is rendered with a CheckBox
to the right of the 'disclosure node' (i.e. the arrow). The item stored
in TreeItem.getValue()
will then have the StringConverter
called on it, and this text will take all remaining horizontal space.
Unlike forTreeView()
, this cell factory does not handle
updating the state of parent or children TreeItems - it simply toggles
the ObservableValue<Boolean>
that is provided, and no more. Of
course, this functionality can then be implemented externally by adding
observers to the ObservableValue<Boolean>
, and toggling the state
of other properties as necessary.
T
- The type of the elements contained within the TreeItem
instances.getSelectedProperty
- A Callback
that, given an object of
type TreeItemObservableValue<Boolean>
that represents whether the given item is selected or not. This
ObservableValue<Boolean>
will be bound bidirectionally
(meaning that the CheckBox in the cell will set/unset this property
based on user interactions, and the CheckBox will reflect the state
of the ObservableValue<Boolean>
, if it changes externally).Callback
that will return a TreeCell that is able to
work on the type of element contained within the TreeView root, and
all of its children (recursively).public static <T> Callback<TreeView<T>,TreeCell<T>> forTreeView(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedProperty, StringConverter<TreeItem<T>> converter)
forTreeView()
, this method does not assume that all TreeItem
instances in the TreeView are CheckBoxTreeItem
.
When used in a TreeView, the CheckBoxCell is rendered with a CheckBox
to the right of the 'disclosure node' (i.e. the arrow). The item stored
in TreeItem.getValue()
will then have the the StringConverter
called on it, and this text will take all remaining horizontal space.
Unlike forTreeView()
, this cell factory does not handle
updating the state of parent or children TreeItems - it simply toggles
the ObservableValue<Boolean>
that is provided, and no more. Of
course, this functionality can then be implemented externally by adding
observers to the ObservableValue<Boolean>
, and toggling the state
of other properties as necessary.
T
- The type of the elements contained within the TreeItem
instances.getSelectedProperty
- A Callback that, given an object of
type TreeItemObservableValue<Boolean>
that represents whether the given item is selected or not. This
ObservableValue<Boolean>
will be bound bidirectionally
(meaning that the CheckBox in the cell will set/unset this property
based on user interactions, and the CheckBox will reflect the state of
the ObservableValue<Boolean>
, if it changes externally).converter
- A StringConverter that, give an object of type TreeItemforTreeView(Callback)
is to simply call .toString() on all non-null items (and to just
return an empty string in cases where the given item is null).Callback
that will return a TreeCell that is able to
work on the type of element contained within the TreeView root, and
all of its children (recursively).public final ObjectProperty<StringConverter<TreeItem<T>>> converterProperty()
StringConverter
property.getConverter()
,
setConverter(StringConverter)
public final void setConverter(StringConverter<TreeItem<T>> value)
StringConverter
to be used in this cell.public final StringConverter<TreeItem<T>> getConverter()
StringConverter
used in this cell.public final ObjectProperty<Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>>> selectedStateCallbackProperty()
Callback
that is bound to by the
CheckBox shown on screen.public final void setSelectedStateCallback(Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> value)
Callback
that is bound to by the CheckBox shown on screen.public final Callback<TreeItem<T>,ObservableValue<java.lang.Boolean>> getSelectedStateCallback()
Callback
that is bound to by the CheckBox shown on screen.public void updateItem(T item, boolean empty)
Updates the item associated with this Cell. This method should only be called by Skin implementations of ListView, TableView, TreeView, or other controls using Cells. It is not intended to be called by application developers.
Because null
is a perfectly valid value in the application
domain, Cell needs some way to distinguish whether or not the cell
actually holds a value. The empty
flag indicates this.
It is an error to supply a non-null item
but a true value for
empty
.
updateItem
in class Cell<T>
item
- The new item for the cellempty
- whether or not this cell represents data from the list. If it
is empty, then it does not represent any domain data, but is a cell
being used to render an "empty" row.Copyright (c) 2008, 2012, Oracle and/or its affiliates. All rights reserved. Use is subject to