java.lang.Object | ||||
↳ | java.awt.Component | |||
↳ | java.awt.Container | |||
↳ | javax.swing.JComponent | |||
↳ | javax.swing.JTree |
![]() |
A control that displays a set of hierarchical data as an outline. You can find task-oriented documentation and examples of using trees in How to Use Trees, a section in The Java Tutorial.
A specific node in a tree can be identified either by a
TreePath
(an object
that encapsulates a node and all of its ancestors), or by its
display row, where each row in the display area displays one node.
An expanded node is a non-leaf node (as identified by
TreeModel.isLeaf(node)
returning false) that will displays
its children when all its ancestors are expanded.
A collapsed
node is one which hides them. A hidden node is one which is
under a collapsed ancestor. All of a viewable nodes parents
are expanded, but may or may not be displayed. A displayed node
is both viewable and in the display area, where it can be seen.
The following JTree
methods use "visible" to mean "displayed":
isRootVisible()
setRootVisible()
scrollPathToVisible()
scrollRowToVisible()
getVisibleRowCount()
setVisibleRowCount()
The next group of JTree
methods use "visible" to mean
"viewable" (under an expanded parent):
isVisible()
makeVisible()
If you are interested in knowing when the selection changes implement
the TreeSelectionListener
interface and add the instance
using the method addTreeSelectionListener
.
valueChanged
will be invoked when the
selection changes, that is if the user clicks twice on the same
node valueChanged
will only be invoked once.
If you are interested in detecting either double-click events or when a user clicks on a node, regardless of whether or not it was selected, we recommend you do the following:
final JTree tree = ...; MouseListener ml = new MouseAdapter() { public void mousePressed(MouseEvent e) { int selRow = tree.getRowForLocation(e.getX(), e.getY()); TreePath selPath = tree.getPathForLocation(e.getX(), e.getY()); if(selRow != -1) { if(e.getClickCount() == 1) { mySingleClick(selRow, selPath); } else if(e.getClickCount() == 2) { myDoubleClick(selRow, selPath); } } } }; tree.addMouseListener(ml);NOTE: This example obtains both the path and row, but you only need to get the one you're interested in.
To use JTree
to display compound nodes
(for example, nodes containing both
a graphic icon and text), subclass TreeCellRenderer
and use
setCellRenderer(TreeCellRenderer)
to tell the tree to use it. To edit such nodes,
subclass TreeCellEditor
and use setCellEditor(TreeCellEditor)
.
Like all JComponent
classes, you can use InputMap
and
ActionMap
to associate an Action
object with a KeyStroke
and execute the action under specified conditions.
Warning: Swing is not thread safe. For more information see Swing's Threading Policy.
Warning:
Serialized objects of this class will not be compatible with
future Swing releases. The current serialization support is
appropriate for short term storage or RMI between applications running
the same version of Swing. As of 1.4, support for long term storage
of all JavaBeansTM
has been added to the java.beans
package.
Please see XMLEncoder
.
Nested Classes | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
JTree.AccessibleJTree | This class implements accessibility support for the
JTree class. |
||||||||||
JTree.DropLocation | A subclass of TransferHandler.DropLocation representing
a drop location for a JTree . |
||||||||||
JTree.DynamicUtilTreeNode | DynamicUtilTreeNode can wrap
vectors/hashtables/arrays/strings and
create the appropriate children tree nodes as necessary. |
||||||||||
JTree.EmptySelectionModel | EmptySelectionModel is a TreeSelectionModel
that does not allow anything to be selected. |
||||||||||
JTree.TreeModelHandler | Listens to the model and updates the expandedState
accordingly when nodes are removed, or changed. |
||||||||||
JTree.TreeSelectionRedirector | Handles creating a new TreeSelectionEvent with the
JTree as the
source and passing it off to all the listeners. |
Constants | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
String | ANCHOR_SELECTION_PATH_PROPERTY | Bound property name for anchor selection path. | |||||||||
String | CELL_EDITOR_PROPERTY | Bound property name for cellEditor . |
|||||||||
String | CELL_RENDERER_PROPERTY | Bound property name for cellRenderer . |
|||||||||
String | EDITABLE_PROPERTY | Bound property name for editable . |
|||||||||
String | EXPANDS_SELECTED_PATHS_PROPERTY | Bound property name for expands selected paths property | |||||||||
String | INVOKES_STOP_CELL_EDITING_PROPERTY | Bound property name for messagesStopCellEditing . |
|||||||||
String | LARGE_MODEL_PROPERTY | Bound property name for largeModel . |
|||||||||
String | LEAD_SELECTION_PATH_PROPERTY | Bound property name for leadSelectionPath . |
|||||||||
String | ROOT_VISIBLE_PROPERTY | Bound property name for rootVisible . |
|||||||||
String | ROW_HEIGHT_PROPERTY | Bound property name for rowHeight . |
|||||||||
String | SCROLLS_ON_EXPAND_PROPERTY | Bound property name for scrollsOnExpand . |
|||||||||
String | SELECTION_MODEL_PROPERTY | Bound property name for selectionModel. | |||||||||
String | SHOWS_ROOT_HANDLES_PROPERTY | Bound property name for showsRootHandles . |
|||||||||
String | TOGGLE_CLICK_COUNT_PROPERTY | Bound property name for toggleClickCount . |
|||||||||
String | TREE_MODEL_PROPERTY | Bound property name for treeModel . |
|||||||||
String | VISIBLE_ROW_COUNT_PROPERTY | Bound property name for visibleRowCount . |
[Expand]
Inherited Constants | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() | |||||||||||
![]() | |||||||||||
![]() |
Fields | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
cellEditor | Editor for the entries. | ||||||||||
cellRenderer | The cell used to draw nodes. | ||||||||||
editable | Is the tree editable? Default is false. | ||||||||||
invokesStopCellEditing | If true, when editing is to be stopped by way of selection changing,
data in tree changing or other means stopCellEditing
is invoked, and changes are saved. |
||||||||||
largeModel | Is this tree a large model? This is a code-optimization setting. | ||||||||||
rootVisible | True if the root node is displayed, false if its children are the highest visible nodes. | ||||||||||
rowHeight | Height to use for each display row. | ||||||||||
scrollsOnExpand | If true, when a node is expanded, as many of the descendants are scrolled to be visible. | ||||||||||
selectionModel | Models the set of selected nodes in this tree. | ||||||||||
selectionRedirector | Creates a new event and passed it off the
selectionListeners . |
||||||||||
showsRootHandles | True if handles are displayed at the topmost level of the tree. | ||||||||||
toggleClickCount | Number of mouse clicks before a node is expanded. | ||||||||||
treeModel | The model that defines the tree displayed by this object. | ||||||||||
treeModelListener | Updates the expandedState . |
||||||||||
visibleRowCount | Number of rows to make visible at one time. |
[Expand]
Inherited Fields | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() |
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Returns a
JTree with a sample model. | |||||||||||
Returns a
JTree with each element of the
specified array as the
child of a new root node which is not displayed. | |||||||||||
Returns a
JTree with each element of the specified
Vector as the
child of a new root node which is not displayed. | |||||||||||
Returns a
JTree created from a Hashtable
which does not display with root. | |||||||||||
Returns a
JTree with the specified
TreeNode as its root,
which displays the root node. | |||||||||||
Returns a
JTree with the specified TreeNode
as its root, which
displays the root node and which decides whether a node is a
leaf node in the specified manner. | |||||||||||
Returns an instance of
JTree which displays the root node
-- the tree is created using the specified data model. |
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Adds the paths between index0 and index1, inclusive, to the
selection.
| |||||||||||
Adds the node identified by the specified
TreePath
to the current selection. | |||||||||||
Adds each path in the array of paths to the current selection.
| |||||||||||
Adds the path at the specified row to the current selection.
| |||||||||||
Adds the paths at each of the specified rows to the current selection.
| |||||||||||
Adds a listener for
TreeExpansion events. | |||||||||||
Adds a listener for
TreeSelection events. | |||||||||||
Adds a listener for
TreeWillExpand events. | |||||||||||
Cancels the current editing session.
| |||||||||||
Clears the selection.
| |||||||||||
Ensures that the node identified by the specified path is
collapsed and viewable.
| |||||||||||
Ensures that the node in the specified row is collapsed.
| |||||||||||
Called by the renderers to convert the specified value to
text.
| |||||||||||
Ensures that the node identified by the specified path is
expanded and viewable.
| |||||||||||
Ensures that the node in the specified row is expanded and
viewable.
| |||||||||||
Notifies all listeners that have registered interest for
notification on this event type.
| |||||||||||
Notifies all listeners that have registered interest for
notification on this event type.
| |||||||||||
Notifies all listeners that have registered interest for
notification on this event type.
| |||||||||||
Notifies all listeners that have registered interest for
notification on this event type.
| |||||||||||
Gets the AccessibleContext associated with this JTree.
| |||||||||||
Returns the path identified as the anchor.
| |||||||||||
Returns the editor used to edit entries in the tree.
| |||||||||||
Returns the current
TreeCellRenderer
that is rendering each cell. | |||||||||||
Returns the path to the node that is closest to x,y.
| |||||||||||
Returns the row to the node that is closest to x,y.
| |||||||||||
Returns whether or not automatic drag handling is enabled.
| |||||||||||
Returns the location that this component should visually indicate
as the drop location during a DnD operation over the component,
or
null if no location is to currently be shown. | |||||||||||
Returns the drop mode for this component.
| |||||||||||
Returns the path to the element that is currently being edited.
| |||||||||||
Returns an
Enumeration of the descendants of the
path parent that
are currently expanded. | |||||||||||
Returns the
expandsSelectedPaths property. | |||||||||||
Returns the indicator that tells what happens when editing is
interrupted.
| |||||||||||
Returns the last path component in the first node of the current
selection.
| |||||||||||
Returns the path identified as the lead.
| |||||||||||
Returns the row index corresponding to the lead path.
| |||||||||||
Returns the last selected row.
| |||||||||||
Gets the first selected row.
| |||||||||||
Returns the
TreeModel that is providing the data. | |||||||||||
Returns the TreePath to the next tree element that
begins with a prefix.
| |||||||||||
Returns the
Rectangle that the specified node will be drawn
into. | |||||||||||
Returns the path for the node at the specified location.
| |||||||||||
Returns the path for the specified row.
| |||||||||||
Returns the preferred display size of a
JTree . | |||||||||||
Returns the
Rectangle that the node at the specified row is
drawn in. | |||||||||||
Returns the number of rows that are currently being displayed.
| |||||||||||
Returns the row for the specified location.
| |||||||||||
Returns the row that displays the node identified by the specified
path.
| |||||||||||
Returns the height of each row.
| |||||||||||
Returns the amount for a block increment, which is the height or
width of
visibleRect , based on orientation . | |||||||||||
Returns false to indicate that the height of the viewport does not
determine the height of the table, unless the preferred height
of the tree is smaller than the viewports height.
| |||||||||||
Returns false to indicate that the width of the viewport does not
determine the width of the table, unless the preferred width of
the tree is smaller than the viewports width.
| |||||||||||
Returns the amount to increment when scrolling.
| |||||||||||
Returns the value of the
scrollsOnExpand property. | |||||||||||
Returns the number of nodes selected.
| |||||||||||
Returns the model for selections.
| |||||||||||
Returns the path to the first selected node.
| |||||||||||
Returns the paths of all selected values.
| |||||||||||
Returns all of the currently selected rows.
| |||||||||||
Returns the value of the
showsRootHandles property. | |||||||||||
Returns the number of mouse clicks needed to expand or close a node.
| |||||||||||
Overrides
JComponent 's getToolTipText
method in order to allow
renderer's tips to be used if it has text set. | |||||||||||
Returns an array of all the
TreeExpansionListener s added
to this JTree with addTreeExpansionListener(). | |||||||||||
Returns an array of all the
TreeSelectionListener s added
to this JTree with addTreeSelectionListener(). | |||||||||||
Returns an array of all the
TreeWillExpandListener s added
to this JTree with addTreeWillExpandListener(). | |||||||||||
Returns the L&F object that renders this component.
| |||||||||||
Returns the name of the L&F class that renders this component.
| |||||||||||
Returns the number of rows that are displayed in the display area.
| |||||||||||
Returns true if the node identified by the path has ever been
expanded.
| |||||||||||
Returns true if the node at the specified display row is collapsed.
| |||||||||||
Returns true if the value identified by path is currently collapsed,
this will return false if any of the values in path are currently
not being displayed.
| |||||||||||
Returns true if the tree is editable.
| |||||||||||
Returns true if the tree is being edited.
| |||||||||||
Returns true if the node at the specified display row is currently
expanded.
| |||||||||||
Returns true if the node identified by the path is currently expanded,
| |||||||||||
Returns true if the height of each display row is a fixed size.
| |||||||||||
Returns true if the tree is configured for a large model.
| |||||||||||
Returns
isEditable . | |||||||||||
Returns true if the item identified by the path is currently selected.
| |||||||||||
Returns true if the root node of the tree is displayed.
| |||||||||||
Returns true if the node identified by row is selected.
| |||||||||||
Returns true if the selection is currently empty.
| |||||||||||
Returns true if the value identified by path is currently viewable,
which means it is either the root or all of its parents are expanded.
| |||||||||||
Ensures that the node identified by path is currently viewable.
| |||||||||||
Removes the nodes between index0 and index1, inclusive, from the
selection.
| |||||||||||
Removes the node identified by the specified path from the current
selection.
| |||||||||||
Removes the nodes identified by the specified paths from the
current selection.
| |||||||||||
Removes the row at the index
row from the current
selection. | |||||||||||
Removes the rows that are selected at each of the specified
rows.
| |||||||||||
Removes a listener for
TreeExpansion events. | |||||||||||
Removes a
TreeSelection listener. | |||||||||||
Removes a listener for
TreeWillExpand events. | |||||||||||
Makes sure all the path components in path are expanded (except
for the last path component) and scrolls so that the
node identified by the path is displayed.
| |||||||||||
Scrolls the item identified by row until it is displayed.
| |||||||||||
Sets the path identified as the anchor.
| |||||||||||
Sets the cell editor.
| |||||||||||
Sets the
TreeCellRenderer that will be used to
draw each cell. | |||||||||||
Turns on or off automatic drag handling.
| |||||||||||
Sets the drop mode for this component.
| |||||||||||
Determines whether the tree is editable.
| |||||||||||
Configures the
expandsSelectedPaths property. | |||||||||||
Determines what happens when editing is interrupted by selecting
another node in the tree, a change in the tree's data, or by some
other means.
| |||||||||||
Specifies whether the UI should use a large model.
| |||||||||||
Sets the path identifies as the lead.
| |||||||||||
Sets the
TreeModel that will provide the data. | |||||||||||
Determines whether or not the root node from
the
TreeModel is visible. | |||||||||||
Sets the height of each cell, in pixels.
| |||||||||||
Sets the
scrollsOnExpand property,
which determines whether the
tree might scroll to show previously hidden children. | |||||||||||
Selects the nodes between index0 and index1, inclusive.
| |||||||||||
Sets the tree's selection model.
| |||||||||||
Selects the node identified by the specified path.
| |||||||||||
Selects the nodes identified by the specified array of paths.
| |||||||||||
Selects the node at the specified row in the display.
| |||||||||||
Selects the nodes corresponding to each of the specified rows
in the display.
| |||||||||||
Sets the value of the
showsRootHandles property,
which specifies whether the node handles should be displayed. | |||||||||||
Sets the number of mouse clicks before a node will expand or close.
| |||||||||||
Sets the L&F object that renders this component.
| |||||||||||
Sets the number of rows that are to be displayed.
| |||||||||||
Selects the node identified by the specified path and initiates
editing.
| |||||||||||
Ends the current editing session.
| |||||||||||
Sent when the tree has changed enough that we need to resize
the bounds, but not enough that we need to remove the
expanded node set (e.g nodes were expanded or collapsed, or
nodes were inserted into the tree).
| |||||||||||
Notification from the
UIManager that the L&F has changed. |
Protected Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Clears the cache of toggled tree paths.
| |||||||||||
Returns a
TreeModel wrapping the specified object. | |||||||||||
Creates and returns an instance of
TreeModelHandler . | |||||||||||
Notifies all listeners that have registered interest for
notification on this event type.
| |||||||||||
Creates and returns a sample
TreeModel . | |||||||||||
Returns an
Enumeration of TreePaths
that have been expanded that
are descendants of parent . | |||||||||||
Returns
JTreePath instances representing the path
between index0 and index1 (including index1). | |||||||||||
Returns a string representation of this
JTree . | |||||||||||
Removes any paths in the selection that are descendants of
path . | |||||||||||
Removes any descendants of the
TreePaths in
toRemove
that have been expanded. | |||||||||||
Sets the expanded state of this
JTree . |
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() | |||||||||||
![]() | |||||||||||
![]() | |||||||||||
![]() | |||||||||||
![]() | |||||||||||
![]() | |||||||||||
![]() | |||||||||||
![]() |
Bound property name for anchor selection path.
Bound property name for cellEditor
.
Bound property name for cellRenderer
.
Bound property name for editable
.
Bound property name for expands selected paths property
Bound property name for messagesStopCellEditing
.
Bound property name for largeModel
.
Bound property name for leadSelectionPath
.
Bound property name for rootVisible
.
Bound property name for rowHeight
.
Bound property name for scrollsOnExpand
.
Bound property name for selectionModel.
Bound property name for showsRootHandles
.
Bound property name for toggleClickCount
.
Bound property name for treeModel
.
Bound property name for visibleRowCount
.
The cell used to draw nodes. If null
, the UI uses a default
cellRenderer
.
Is the tree editable? Default is false.
If true, when editing is to be stopped by way of selection changing,
data in tree changing or other means stopCellEditing
is invoked, and changes are saved. If false,
cancelCellEditing
is invoked, and changes
are discarded. Default is false.
Is this tree a large model? This is a code-optimization setting. A large model can be used when the cell height is the same for all nodes. The UI will then cache very little information and instead continually message the model. Without a large model the UI caches most of the information, resulting in fewer method calls to the model.
This value is only a suggestion to the UI. Not all UIs will take advantage of it. Default value is false.
True if the root node is displayed, false if its children are the highest visible nodes.
Height to use for each display row. If this is <= 0 the renderer determines the height for each row.
If true, when a node is expanded, as many of the descendants are scrolled to be visible.
Creates a new event and passed it off the
selectionListeners
.
True if handles are displayed at the topmost level of the tree.
A handle is a small icon that displays adjacent to the node which allows the user to click once to expand or collapse the node. A common interface shows a plus sign (+) for a node which can be expanded and a minus sign (-) for a node which can be collapsed. Handles are always shown for nodes below the topmost level.
If the rootVisible
setting specifies that the root
node is to be displayed, then that is the only node at the topmost
level. If the root node is not displayed, then all of its
children are at the topmost level of the tree. Handles are
always displayed for nodes other than the topmost.
If the root node isn't visible, it is generally a good to make this value true. Otherwise, the tree looks exactly like a list, and users may not know that the "list entries" are actually tree nodes.
Number of mouse clicks before a node is expanded.
Number of rows to make visible at one time. This value is used for
the Scrollable
interface. It determines the preferred
size of the display area.
Returns a JTree
with a sample model.
The default model used by the tree defines a leaf node as any node
without children.
Returns a JTree
with each element of the
specified array as the
child of a new root node which is not displayed.
By default, the tree defines a leaf node as any node without
children.
value | an array of Object s |
---|
Returns a JTree
with each element of the specified
Vector
as the
child of a new root node which is not displayed. By default, the
tree defines a leaf node as any node without children.
value | a Vector |
---|
Returns a JTree
created from a Hashtable
which does not display with root.
Each value-half of the key/value pairs in the HashTable
becomes a child of the new root node. By default, the tree defines
a leaf node as any node without children.
value | a Hashtable |
---|
Returns a JTree
with the specified
TreeNode
as its root,
which displays the root node.
By default, the tree defines a leaf node as any node without children.
root | a TreeNode object |
---|
Returns a JTree
with the specified TreeNode
as its root, which
displays the root node and which decides whether a node is a
leaf node in the specified manner.
root | a TreeNode object |
---|---|
asksAllowsChildren | if false, any node without children is a leaf node; if true, only nodes that do not allow children are leaf nodes |
Returns an instance of JTree
which displays the root node
-- the tree is created using the specified data model.
newModel | the TreeModel to use as the data model
|
---|
Adds the paths between index0 and index1, inclusive, to the selection.
index0 | an integer specifying a display row, where 0 is the first row in the display |
---|---|
index1 | an integer specifying a second display row |
Adds the node identified by the specified TreePath
to the current selection. If any component of the path isn't
viewable, and getExpandsSelectedPaths
is true it is
made viewable.
Note that JTree
does not allow duplicate nodes to
exist as children under the same parent -- each sibling must be
a unique object.
path | the TreePath to add
|
---|
Adds each path in the array of paths to the current selection. If
any component of any of the paths isn't viewable and
getExpandsSelectedPaths
is true, it is
made viewable.
Note that JTree
does not allow duplicate nodes to
exist as children under the same parent -- each sibling must be
a unique object.
paths | an array of TreePath objects that specifies
the nodes to add
|
---|
Adds the path at the specified row to the current selection.
row | an integer specifying the row of the node to add, where 0 is the first row in the display |
---|
Adds the paths at each of the specified rows to the current selection.
rows | an array of ints specifying the rows to add, where 0 indicates the first row in the display |
---|
Adds a listener for TreeExpansion
events.
tel | a TreeExpansionListener that will be notified when a tree node is expanded or collapsed (a "negative expansion") |
---|
Adds a listener for TreeSelection
events.
tsl | the TreeSelectionListener that will be notified
when a node is selected or deselected (a "negative
selection")
|
---|
Adds a listener for TreeWillExpand
events.
tel | a TreeWillExpandListener that will be notified
when a tree node will be expanded or collapsed (a "negative
expansion")
|
---|
Cancels the current editing session. Has no effect if the tree isn't being edited.
Clears the selection.
Ensures that the node identified by the specified path is collapsed and viewable.
path | the TreePath identifying a node
|
---|
Ensures that the node in the specified row is collapsed.
If row
is < 0 or >= getRowCount
this
will have no effect.
row | an integer specifying a display row, where 0 is the first row in the display |
---|
Called by the renderers to convert the specified value to
text. This implementation returns value.toString
, ignoring
all other arguments. To control the conversion, subclass this
method and use any of the arguments you need.
value | the Object to convert to text |
---|---|
selected | true if the node is selected |
expanded | true if the node is expanded |
leaf | true if the node is a leaf node |
row | an integer specifying the node's display row, where 0 is the first row in the display |
hasFocus | true if the node has the focus |
String
representation of the node's value
Ensures that the node identified by the specified path is expanded and viewable. If the last item in the path is a leaf, this will have no effect.
path | the TreePath identifying a node
|
---|
Ensures that the node in the specified row is expanded and viewable.
If row
is < 0 or >= getRowCount
this
will have no effect.
row | an integer specifying a display row, where 0 is the first row in the display |
---|
Notifies all listeners that have registered interest for
notification on this event type. The event instance
is lazily created using the path
parameter.
path | the TreePath indicating the node that was
collapsed |
---|
Notifies all listeners that have registered interest for
notification on this event type. The event instance
is lazily created using the path
parameter.
path | the TreePath indicating the node that was
expanded |
---|
Notifies all listeners that have registered interest for
notification on this event type. The event instance
is lazily created using the path
parameter.
path | the TreePath indicating the node that was
expanded |
---|
ExpandVetoException |
---|
Notifies all listeners that have registered interest for
notification on this event type. The event instance
is lazily created using the path
parameter.
path | the TreePath indicating the node that was
expanded |
---|
ExpandVetoException |
---|
Gets the AccessibleContext associated with this JTree. For JTrees, the AccessibleContext takes the form of an AccessibleJTree. A new AccessibleJTree instance is created if necessary.
Returns the path identified as the anchor.
Returns the editor used to edit entries in the tree.
TreeCellEditor
in use,
or null
if the tree cannot be edited
Returns the current TreeCellRenderer
that is rendering each cell.
TreeCellRenderer
that is rendering each cell
Returns the path to the node that is closest to x,y. If
no nodes are currently viewable, or there is no model, returns
null
, otherwise it always returns a valid path. To test if
the node is exactly at x, y, get the node's bounds and
test x, y against that.
x | an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin |
---|---|
y | an integer giving the number of pixels vertically from the top of the display area, minus any top margin |
TreePath
for the node closest to that location,
null
if nothing is viewable or there is no modelReturns the row to the node that is closest to x,y. If no nodes are viewable or there is no model, returns -1. Otherwise, it always returns a valid row. To test if the returned object is exactly at x, y, get the bounds for the node at the returned row and test x, y against that.
x | an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin |
---|---|
y | an integer giving the number of pixels vertically from the top of the display area, minus any top margin |
Returns whether or not automatic drag handling is enabled.
dragEnabled
propertyReturns the location that this component should visually indicate
as the drop location during a DnD operation over the component,
or null
if no location is to currently be shown.
This method is not meant for querying the drop location
from a TransferHandler
, as the drop location is only
set after the TransferHandler
's canImport
has returned and has allowed for the location to be shown.
When this property changes, a property change event with name "dropLocation" is fired by the component.
Returns the drop mode for this component.
Returns the path to the element that is currently being edited.
TreePath
for the node being edited
Returns an Enumeration
of the descendants of the
path parent
that
are currently expanded. If parent
is not currently
expanded, this will return null
.
If you expand/collapse nodes while
iterating over the returned Enumeration
this may not return all
the expanded paths, or may return paths that are no longer expanded.
parent | the path which is to be examined |
---|
Enumeration
of the descendents of
parent
, or null
if
parent
is not currently expanded
Returns the expandsSelectedPaths
property.
Returns the indicator that tells what happens when editing is interrupted.
Returns the last path component in the first node of the current selection.
Object
in the first selected node's
TreePath
,
or null
if nothing is selectedReturns the path identified as the lead.
Returns the row index corresponding to the lead path.
leadPath
is null
Returns the last selected row.
Gets the first selected row.
Returns the TreeModel
that is providing the data.
TreeModel
that is providing the data
Returns the TreePath to the next tree element that
begins with a prefix. To handle the conversion of a
TreePath
into a String, convertValueToText
is used.
prefix | the string to test for a match |
---|---|
startingRow | the row for starting the search |
bias | the search direction, either Position.Bias.Forward or Position.Bias.Backward. |
IllegalArgumentException | if prefix is null or startingRow is out of bounds |
---|
Returns the Rectangle
that the specified node will be drawn
into. Returns null
if any component in the path is hidden
(under a collapsed parent).
Note:
This method returns a valid rectangle, even if the specified
node is not currently displayed.
path | the TreePath identifying the node |
---|
Rectangle
the node is drawn in,
or null
Returns the path for the node at the specified location.
x | an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin |
---|---|
y | an integer giving the number of pixels vertically from the top of the display area, minus any top margin |
TreePath
for the node at that location
Returns the path for the specified row. If row
is
not visible, null
is returned.
row | an integer specifying a row |
---|
TreePath
to the specified node,
null
if row < 0
or row > getRowCount()
Returns the preferred display size of a JTree
. The height is
determined from getVisibleRowCount
and the width
is the current preferred width.
Dimension
object containing the preferred size
Returns the Rectangle
that the node at the specified row is
drawn in.
row | the row to be drawn, where 0 is the first row in the display |
---|
Rectangle
the node is drawn in
Returns the number of rows that are currently being displayed.
Returns the row for the specified location.
x | an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin |
---|---|
y | an integer giving the number of pixels vertically from the top of the display area, minus any top margin |
Returns the row that displays the node identified by the specified path.
path | the TreePath identifying a node |
---|
Returns the height of each row. If the returned value is less than or equal to 0 the height for each row is determined by the renderer.
Returns the amount for a block increment, which is the height or
width of visibleRect
, based on orientation
.
visibleRect | the view area visible within the viewport |
---|---|
orientation | either SwingConstants.VERTICAL
or SwingConstants.HORIZONTAL |
direction | less than zero to scroll up/left, greater than zero for down/right. |
Returns false to indicate that the height of the viewport does not determine the height of the table, unless the preferred height of the tree is smaller than the viewports height. In other words: ensure that the tree is never smaller than its viewport.
Returns false to indicate that the width of the viewport does not determine the width of the table, unless the preferred width of the tree is smaller than the viewports width. In other words: ensure that the tree is never smaller than its viewport.
Returns the amount to increment when scrolling. The amount is the height of the first displayed row that isn't completely in view or, if it is totally displayed, the height of the next row in the scrolling direction.
visibleRect | the view area visible within the viewport |
---|---|
orientation | either SwingConstants.VERTICAL
or SwingConstants.HORIZONTAL |
direction | less than zero to scroll up/left, greater than zero for down/right |
Returns the value of the scrollsOnExpand
property.
scrollsOnExpand
property
Returns the number of nodes selected.
Returns the model for selections. This should always return a
non-null
value. If you don't want to allow anything
to be selected
set the selection model to null
, which forces an empty
selection model to be used.
Returns the path to the first selected node.
TreePath
for the first selected node,
or null
if nothing is currently selected
Returns the paths of all selected values.
TreePath
objects indicating the selected
nodes, or null
if nothing is currently selected
Returns all of the currently selected rows. This method is simply
forwarded to the TreeSelectionModel
.
If nothing is selected null
or an empty array will
be returned, based on the TreeSelectionModel
implementation.
Returns the value of the showsRootHandles
property.
showsRootHandles
propertyReturns the number of mouse clicks needed to expand or close a node.
Overrides JComponent
's getToolTipText
method in order to allow
renderer's tips to be used if it has text set.
NOTE: For JTree
to properly display tooltips of its
renderers, JTree
must be a registered component with the
ToolTipManager
. This can be done by invoking
ToolTipManager.sharedInstance().registerComponent(tree)
.
This is not done automatically!
event | the MouseEvent that initiated the
ToolTip display |
---|
null
if event
is null
Returns an array of all the TreeExpansionListener
s added
to this JTree with addTreeExpansionListener().
TreeExpansionListener
s added or an empty
array if no listeners have been addedReturns an array of all the TreeSelectionListener
s added
to this JTree with addTreeSelectionListener().
TreeSelectionListener
s added or an empty
array if no listeners have been addedReturns an array of all the TreeWillExpandListener
s added
to this JTree with addTreeWillExpandListener().
TreeWillExpandListener
s added or an empty
array if no listeners have been addedReturns the L&F object that renders this component.
TreeUI
object that renders this component
Returns the name of the L&F class that renders this component.
Returns the number of rows that are displayed in the display area.
Returns true if the node identified by the path has ever been expanded.
path
has ever been expanded
Returns true if the node at the specified display row is collapsed.
row | the row to check, where 0 is the first row in the display |
---|
Returns true if the value identified by path is currently collapsed, this will return false if any of the values in path are currently not being displayed.
path | the TreePath to check |
---|
Returns true if the tree is editable.
Returns true if the tree is being edited. The item that is being
edited can be obtained using getSelectionPath
.
Returns true if the node at the specified display row is currently expanded.
row | the row to check, where 0 is the first row in the display |
---|
Returns true if the node identified by the path is currently expanded,
path | the TreePath specifying the node to check |
---|
Returns true if the height of each display row is a fixed size.
Returns true if the tree is configured for a large model.
Returns isEditable
. This is invoked from the UI before
editing begins to insure that the given path can be edited. This
is provided as an entry point for subclassers to add filtered
editing without having to resort to creating a new editor.
Returns true if the item identified by the path is currently selected.
path | a TreePath identifying a node |
---|
Returns true if the root node of the tree is displayed.
Returns true if the node identified by row is selected.
row | an integer specifying a display row, where 0 is the first row in the display |
---|
Returns true if the selection is currently empty.
Returns true if the value identified by path is currently viewable, which means it is either the root or all of its parents are expanded. Otherwise, this method returns false.
Ensures that the node identified by path is currently viewable.
path | the TreePath to make visible
|
---|
Removes the nodes between index0 and index1, inclusive, from the selection.
index0 | an integer specifying a display row, where 0 is the first row in the display |
---|---|
index1 | an integer specifying a second display row |
Removes the node identified by the specified path from the current selection.
path | the TreePath identifying a node
|
---|
Removes the nodes identified by the specified paths from the current selection.
paths | an array of TreePath objects that
specifies the nodes to remove
|
---|
Removes the row at the index row
from the current
selection.
row | the row to remove |
---|
Removes the rows that are selected at each of the specified rows.
rows | an array of ints specifying display rows, where 0 is the first row in the display |
---|
Removes a listener for TreeExpansion
events.
tel | the TreeExpansionListener to remove
|
---|
Removes a TreeSelection
listener.
tsl | the TreeSelectionListener to remove
|
---|
Removes a listener for TreeWillExpand
events.
tel | the TreeWillExpandListener to remove
|
---|
Makes sure all the path components in path are expanded (except
for the last path component) and scrolls so that the
node identified by the path is displayed. Only works when this
JTree
is contained in a JScrollPane
.
path | the TreePath identifying the node to
bring into view
|
---|
Scrolls the item identified by row until it is displayed. The minimum
of amount of scrolling necessary to bring the row into view
is performed. Only works when this JTree
is contained in a
JScrollPane
.
row | an integer specifying the row to scroll, where 0 is the first row in the display |
---|
Sets the path identified as the anchor.
The anchor is not maintained by JTree
, rather the UI will
update it.
newPath | the new anchor path |
---|
Sets the cell editor. A null
value implies that the
tree cannot be edited. If this represents a change in the
cellEditor
, the propertyChange
method is invoked on all listeners.
cellEditor | the TreeCellEditor to use |
---|
Sets the TreeCellRenderer
that will be used to
draw each cell.
x | the TreeCellRenderer that is to render each cell |
---|
Turns on or off automatic drag handling. In order to enable automatic
drag handling, this property should be set to true
, and the
tree's TransferHandler
needs to be non-null
.
The default value of the dragEnabled
property is false
.
The job of honoring this property, and recognizing a user drag gesture,
lies with the look and feel implementation, and in particular, the tree's
TreeUI
. When automatic drag handling is enabled, most look and
feels (including those that subclass BasicLookAndFeel
) begin a
drag and drop operation whenever the user presses the mouse button over
an item and then moves the mouse a few pixels. Setting this property to
true
can therefore have a subtle effect on how selections behave.
If a look and feel is used that ignores this property, you can still
begin a drag and drop operation by calling exportAsDrag
on the
tree's TransferHandler
.
b | whether or not to enable automatic drag handling |
---|
HeadlessException | if
b is true and
GraphicsEnvironment.isHeadless()
returns true |
---|
Sets the drop mode for this component. For backward compatibility,
the default for this property is DropMode.USE_SELECTION
.
Usage of one of the other modes is recommended, however, for an
improved user experience. DropMode.ON
, for instance,
offers similar behavior of showing items as selected, but does so without
affecting the actual selection in the tree.
JTree
supports the following drop modes:
DropMode.USE_SELECTION
DropMode.ON
DropMode.INSERT
DropMode.ON_OR_INSERT
The drop mode is only meaningful if this component has a
TransferHandler
that accepts drops.
dropMode | the drop mode to use |
---|
IllegalArgumentException | if the drop mode is unsupported
or null |
---|
Determines whether the tree is editable. Fires a property change event if the new setting is different from the existing setting.
flag | a boolean value, true if the tree is editable |
---|
Configures the expandsSelectedPaths
property. If
true, any time the selection is changed, either via the
TreeSelectionModel
, or the cover methods provided by
JTree
, the TreePath
s parents will be
expanded to make them visible (visible meaning the parent path is
expanded, not necessarily in the visible rectangle of the
JTree
). If false, when the selection
changes the nodes parent is not made visible (all its parents expanded).
This is useful if you wish to have your selection model maintain paths
that are not always visible (all parents expanded).
newValue | the new value for expandsSelectedPaths |
---|
Determines what happens when editing is interrupted by selecting
another node in the tree, a change in the tree's data, or by some
other means. Setting this property to true
causes the
changes to be automatically saved when editing is interrupted.
Fires a property change for the INVOKES_STOP_CELL_EDITING_PROPERTY.
newValue | true means that stopCellEditing is invoked
when editing is interrupted, and data is saved; false means that
cancelCellEditing is invoked, and changes are lost |
---|
Specifies whether the UI should use a large model. (Not all UIs will implement this.) Fires a property change for the LARGE_MODEL_PROPERTY.
newValue | true to suggest a large model to the UI |
---|
Sets the path identifies as the lead. The lead may not be selected.
The lead is not maintained by JTree
,
rather the UI will update it.
newPath | the new lead path |
---|
Sets the TreeModel
that will provide the data.
newModel | the TreeModel that is to provide the data |
---|
Determines whether or not the root node from
the TreeModel
is visible.
rootVisible | true if the root node of the tree is to be displayed |
---|
Sets the height of each cell, in pixels. If the specified value is less than or equal to zero the current cell renderer is queried for each row's height.
rowHeight | the height of each cell, in pixels |
---|
Sets the scrollsOnExpand
property,
which determines whether the
tree might scroll to show previously hidden children.
If this property is true
(the default),
when a node expands
the tree can use scrolling to make
the maximum possible number of the node's descendants visible.
In some look and feels, trees might not need to scroll when expanded;
those look and feels will ignore this property.
newValue | false to disable scrolling on expansion;
true to enable it |
---|
Selects the nodes between index0 and index1, inclusive.
index0 | an integer specifying a display row, where 0 is the first row in the display |
---|---|
index1 | an integer specifying a second display row |
Sets the tree's selection model. When a null
value is
specified an empty
selectionModel
is used, which does not allow selections.
selectionModel | the TreeSelectionModel to use,
or null to disable selections |
---|
Selects the node identified by the specified path. If any
component of the path is hidden (under a collapsed node), and
getExpandsSelectedPaths
is true it is
exposed (made viewable).
path | the TreePath specifying the node to select
|
---|
Selects the nodes identified by the specified array of paths.
If any component in any of the paths is hidden (under a collapsed
node), and getExpandsSelectedPaths
is true
it is exposed (made viewable).
paths | an array of TreePath objects that specifies
the nodes to select
|
---|
Selects the node at the specified row in the display.
row | the row to select, where 0 is the first row in the display |
---|
Selects the nodes corresponding to each of the specified rows
in the display. If a particular element of rows
is
< 0 or >= getRowCount
, it will be ignored.
If none of the elements
in rows
are valid rows, the selection will
be cleared. That is it will be as if clearSelection
was invoked.
rows | an array of ints specifying the rows to select, where 0 indicates the first row in the display |
---|
Sets the value of the showsRootHandles
property,
which specifies whether the node handles should be displayed.
The default value of this property depends on the constructor
used to create the JTree
.
Some look and feels might not support handles;
they will ignore this property.
newValue | true if root handles should be displayed;
otherwise, false |
---|
Sets the number of mouse clicks before a node will expand or close. The default is two.
Sets the L&F object that renders this component.
ui | the TreeUI L&F object |
---|
Sets the number of rows that are to be displayed.
This will only work if the tree is contained in a
JScrollPane
,
and will adjust the preferred size and size of that scrollpane.
newCount | the number of rows to display |
---|
Selects the node identified by the specified path and initiates
editing. The edit-attempt fails if the CellEditor
does not allow
editing for the specified item.
path | the TreePath identifying a node
|
---|
Ends the current editing session.
(The DefaultTreeCellEditor
object saves any edits that are currently in progress on a cell.
Other implementations may operate differently.)
Has no effect if the tree isn't being edited.
Note:
To make edit-saves automatic whenever the user changes their position in the tree, usesetInvokesStopCellEditing(boolean)
.
Sent when the tree has changed enough that we need to resize the bounds, but not enough that we need to remove the expanded node set (e.g nodes were expanded or collapsed, or nodes were inserted into the tree). You should never have to invoke this, the UI will invoke this as it needs to.
Notification from the UIManager
that the L&F has changed.
Replaces the current UI object with the latest version from the
UIManager
.
Clears the cache of toggled tree paths. This does NOT send out
any TreeExpansionListener
events.
Returns a TreeModel
wrapping the specified object.
If the object is:
Object
s,
Hashtable
, or
Vector
value | the Object used as the foundation for
the TreeModel |
---|
TreeModel
wrapping the specified object
Creates and returns an instance of TreeModelHandler
.
The returned
object is responsible for updating the expanded state when the
TreeModel
changes.
For more information on what expanded state means, see the JTree description above.
Notifies all listeners that have registered interest for notification on this event type.
e | the TreeSelectionEvent to be fired;
generated by the
TreeSelectionModel
when a node is selected or deselected |
---|
Creates and returns a sample TreeModel
.
Used primarily for beanbuilders to show something interesting.
TreeModel
Returns an Enumeration
of TreePaths
that have been expanded that
are descendants of parent
.
Returns JTreePath
instances representing the path
between index0 and index1 (including index1).
Returns null
if there is no tree.
index0 | an integer specifying a display row, where 0 is the first row in the display |
---|---|
index1 | an integer specifying a second display row |
TreePath
objects, one for each
node between index0 and index1, inclusive; or null
if there is no tree
Returns a string representation of this JTree
.
This method
is intended to be used only for debugging purposes, and the
content and format of the returned string may vary between
implementations. The returned string may be empty but may not
be null
.
JTree
.
Removes any paths in the selection that are descendants of
path
. If includePath
is true and
path
is selected, it will be removed from the selection.
Removes any descendants of the TreePaths
in
toRemove
that have been expanded.
Sets the expanded state of this JTree
.
If state
is
true, all parents of path
and path are marked as
expanded. If state
is false, all parents of
path
are marked EXPANDED, but path
itself
is marked collapsed.
This will fail if a TreeWillExpandListener
vetos it.