|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Object![]()
![]()
![]()
java.awt.Component
![]()
![]()
![]()
java.awt.Container
![]()
![]()
![]()
javax.swing.JComponent
![]()
![]()
![]()
javax.swing.JTree
, MenuContainer
, Serializable
, Accessible
, Scrollable

public class JTree

, Accessible

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(javax.swing.tree.TreeCellRenderer)
to tell the tree to use it. To edit such nodes,
subclass TreeCellEditor
and use setCellEditor(javax.swing.tree.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:
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 Class Summary | |
|---|---|
protected class |
JTree.AccessibleJTree
This class implements accessibility support for the JTree class. |
static class |
JTree.DynamicUtilTreeNode
DynamicUtilTreeNode can wrap
vectors/hashtables/arrays/strings and
create the appropriate children tree nodes as necessary. |
protected static class |
JTree.EmptySelectionModel
EmptySelectionModel is a TreeSelectionModel
that does not allow anything to be selected. |
protected class |
JTree.TreeModelHandler
Listens to the model and updates the expandedState
accordingly when nodes are removed, or changed. |
protected class |
JTree.TreeSelectionRedirector
Handles creating a new TreeSelectionEvent with the
JTree as the
source and passing it off to all the listeners. |
Nested classes/interfaces inherited from class javax.swing.JComponent ![]() |
|---|
JComponent.AccessibleJComponent |
Nested classes/interfaces inherited from class java.awt.Container ![]() |
|---|
Container.AccessibleAWTContainer |
Nested classes/interfaces inherited from class java.awt.Component ![]() |
|---|
Component.AccessibleAWTComponent |
| Field Summary | |
|---|---|
static String |
ANCHOR_SELECTION_PATH_PROPERTY
Bound property name for anchor selection path. |
static String |
CELL_EDITOR_PROPERTY
Bound property name for cellEditor. |
static String |
CELL_RENDERER_PROPERTY
Bound property name for cellRenderer. |
protected TreeCellEditor |
cellEditor
Editor for the entries. |
protected TreeCellRenderer |
cellRenderer
The cell used to draw nodes. |
protected boolean |
editable
Is the tree editable? Default is false. |
static String |
EDITABLE_PROPERTY
Bound property name for editable. |
static String |
EXPANDS_SELECTED_PATHS_PROPERTY
Bound property name for expands selected paths property |
static String |
INVOKES_STOP_CELL_EDITING_PROPERTY
Bound property name for messagesStopCellEditing. |
protected boolean |
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. |
static String |
LARGE_MODEL_PROPERTY
Bound property name for largeModel. |
protected boolean |
largeModel
Is this tree a large model? This is a code-optimization setting. |
static String |
LEAD_SELECTION_PATH_PROPERTY
Bound property name for leadSelectionPath. |
static String |
ROOT_VISIBLE_PROPERTY
Bound property name for rootVisible. |
protected boolean |
rootVisible
True if the root node is displayed, false if its children are the highest visible nodes. |
static String |
ROW_HEIGHT_PROPERTY
Bound property name for rowHeight. |
protected int |
rowHeight
Height to use for each display row. |
static String |
SCROLLS_ON_EXPAND_PROPERTY
Bound property name for scrollsOnExpand. |
protected boolean |
scrollsOnExpand
If true, when a node is expanded, as many of the descendants are scrolled to be visible. |
static String |
SELECTION_MODEL_PROPERTY
Bound property name for selectionModel. |
protected TreeSelectionModel |
selectionModel
Models the set of selected nodes in this tree. |
protected JTree.TreeSelectionRedirector |
selectionRedirector
Creates a new event and passed it off the selectionListeners. |
static String |
SHOWS_ROOT_HANDLES_PROPERTY
Bound property name for showsRootHandles. |
protected boolean |
showsRootHandles
True if handles are displayed at the topmost level of the tree. |
static String |
TOGGLE_CLICK_COUNT_PROPERTY
Bound property name for toggleClickCount. |
protected int |
toggleClickCount
Number of mouse clicks before a node is expanded. |
static String |
TREE_MODEL_PROPERTY
Bound property name for treeModel. |
protected TreeModel |
treeModel
The model that defines the tree displayed by this object. |
protected TreeModelListener |
treeModelListener
Updates the expandedState. |
static String |
VISIBLE_ROW_COUNT_PROPERTY
Bound property name for visibleRowCount. |
protected int |
visibleRowCount
Number of rows to make visible at one time. |
Fields inherited from class javax.swing.JComponent ![]() |
|---|
accessibleContext |
Fields inherited from class java.awt.Component ![]() |
|---|
BOTTOM_ALIGNMENT |
Fields inherited from interface java.awt.image.ImageObserver ![]() |
|---|
ABORT |
| Constructor Summary | |
|---|---|
JTree
Returns a JTree with a sample model. |
|
JTree
Returns a JTree created from a Hashtable
which does not display with root. |
|
JTree
Returns a JTree with each element of the
specified array as the
child of a new root node which is not displayed. |
|
JTree
Returns an instance of JTree which displays the root node
-- the tree is created using the specified data model. |
|
JTree
Returns a JTree with the specified
TreeNode as its root,
which displays the root node. |
|
JTree
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. |
|
JTree
Returns a JTree with each element of the specified
Vector as the
child of a new root node which is not displayed. |
|
| Method Summary | |
|---|---|
void |
addSelectionInterval
Adds the paths between index0 and index1, inclusive, to the selection. |
void |
addSelectionPath
Adds the node identified by the specified TreePath
to the current selection. |
void |
addSelectionPaths
Adds each path in the array of paths to the current selection. |
void |
addSelectionRow
Adds the path at the specified row to the current selection. |
void |
addSelectionRows
Adds the paths at each of the specified rows to the current selection. |
void |
addTreeExpansionListener
Adds a listener for TreeExpansion events. |
void |
addTreeSelectionListener
Adds a listener for TreeSelection events. |
void |
addTreeWillExpandListener
Adds a listener for TreeWillExpand events. |
void |
cancelEditing
Cancels the current editing session. |
void |
clearSelection
Clears the selection. |
protected void |
clearToggledPaths
Clears the cache of toggled tree paths. |
void |
collapsePath
Ensures that the node identified by the specified path is collapsed and viewable. |
void |
collapseRow
Ensures that the node in the specified row is collapsed. |
String |
convertValueToText
Called by the renderers to convert the specified value to text. |
protected static TreeModel |
createTreeModel
Returns a TreeModel wrapping the specified object. |
protected TreeModelListener |
createTreeModelListener
Creates and returns an instance of TreeModelHandler. |
void |
expandPath
Ensures that the node identified by the specified path is expanded and viewable. |
void |
expandRow
Ensures that the node in the specified row is expanded and viewable. |
void |
fireTreeCollapsed
Notifies all listeners that have registered interest for notification on this event type. |
void |
fireTreeExpanded
Notifies all listeners that have registered interest for notification on this event type. |
void |
fireTreeWillCollapse
Notifies all listeners that have registered interest for notification on this event type. |
void |
fireTreeWillExpand
Notifies all listeners that have registered interest for notification on this event type. |
protected void |
fireValueChanged
Notifies all listeners that have registered interest for notification on this event type. |
AccessibleContext |
getAccessibleContext
Gets the AccessibleContext associated with this JTree. |
TreePath |
getAnchorSelectionPath
Returns the path identified as the anchor. |
TreeCellEditor |
getCellEditor
Returns the editor used to edit entries in the tree. |
TreeCellRenderer |
getCellRenderer
Returns the current TreeCellRenderer
that is rendering each cell. |
TreePath |
getClosestPathForLocation
Returns the path to the node that is closest to x,y. |
int |
getClosestRowForLocation
Returns the row to the node that is closest to x,y. |
protected static TreeModel |
getDefaultTreeModel
Creates and returns a sample TreeModel. |
protected Enumeration |
getDescendantToggledPaths
Returns an Enumeration of TreePaths
that have been expanded that
are descendants of parent. |
boolean |
getDragEnabled
Gets the value of the dragEnabled property. |
TreePath |
getEditingPath
Returns the path to the element that is currently being edited. |
Enumeration |
getExpandedDescendants
Returns an Enumeration of the descendants of the
path parent that
are currently expanded. |
boolean |
getExpandsSelectedPaths
Returns the expandsSelectedPaths property. |
boolean |
getInvokesStopCellEditing
Returns the indicator that tells what happens when editing is interrupted. |
Object |
getLastSelectedPathComponent
Returns the last path component in the first node of the current selection. |
TreePath |
getLeadSelectionPath
Returns the path identified as the lead. |
int |
getLeadSelectionRow
Returns the row index corresponding to the lead path. |
int |
getMaxSelectionRow
Returns the last selected row. |
int |
getMinSelectionRow
Gets the first selected row. |
TreeModel |
getModel
Returns the TreeModel that is providing the data. |
TreePath |
getNextMatch
Returns the TreePath to the next tree element that begins with a prefix. |
protected TreePath |
getPathBetweenRows
Returns JTreePath instances representing the path
between index0 and index1 (including index1). |
Rectangle |
getPathBounds
Returns the Rectangle that the specified node will be drawn
into. |
TreePath |
getPathForLocation
Returns the path for the node at the specified location. |
TreePath |
getPathForRow
Returns the path for the specified row. |
Dimension |
getPreferredScrollableViewportSize
Returns the preferred display size of a JTree. |
Rectangle |
getRowBounds
Returns the Rectangle that the node at the specified row is
drawn in. |
int |
getRowCount
Returns the number of rows that are currently being displayed. |
int |
getRowForLocation
Returns the row for the specified location. |
int |
getRowForPath
Returns the row that displays the node identified by the specified path. |
int |
getRowHeight
Returns the height of each row. |
int |
getScrollableBlockIncrement
Returns the amount for a block increment, which is the height or width of visibleRect, based on orientation. |
boolean |
getScrollableTracksViewportHeight
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. |
boolean |
getScrollableTracksViewportWidth
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. |
int |
getScrollableUnitIncrement
Returns the amount to increment when scrolling. |
boolean |
getScrollsOnExpand
Returns the value of the scrollsOnExpand property. |
int |
getSelectionCount
Returns the number of nodes selected. |
TreeSelectionModel |
getSelectionModel
Returns the model for selections. |
TreePath |
getSelectionPath
Returns the path to the first selected node. |
TreePath |
getSelectionPaths
Returns the paths of all selected values. |
int[] |
getSelectionRows
Returns all of the currently selected rows. |
boolean |
getShowsRootHandles
Returns the value of the showsRootHandles property. |
int |
getToggleClickCount
Returns the number of mouse clicks needed to expand or close a node. |
String |
getToolTipText
Overrides JComponent's getToolTipText
method in order to allow
renderer's tips to be used if it has text set. |
TreeExpansionListener |
getTreeExpansionListeners
Returns an array of all the TreeExpansionListeners added
to this JTree with addTreeExpansionListener(). |
TreeSelectionListener |
getTreeSelectionListeners
Returns an array of all the TreeSelectionListeners added
to this JTree with addTreeSelectionListener(). |
TreeWillExpandListener |
getTreeWillExpandListeners
Returns an array of all the TreeWillExpandListeners added
to this JTree with addTreeWillExpandListener(). |
TreeUI |
getUI
Returns the L&F object that renders this component. |
String |
getUIClassID
Returns the name of the L&F class that renders this component. |
int |
getVisibleRowCount
Returns the number of rows that are displayed in the display area. |
boolean |
hasBeenExpanded
Returns true if the node identified by the path has ever been expanded. |
boolean |
isCollapsed
Returns true if the node at the specified display row is collapsed. |
boolean |
isCollapsed
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. |
boolean |
isEditable
Returns true if the tree is editable. |
boolean |
isEditing
Returns true if the tree is being edited. |
boolean |
isExpanded
Returns true if the node at the specified display row is currently expanded. |
boolean |
isExpanded
Returns true if the node identified by the path is currently expanded, |
boolean |
isFixedRowHeight
Returns true if the height of each display row is a fixed size. |
boolean |
isLargeModel
Returns true if the tree is configured for a large model. |
boolean |
isPathEditable
Returns isEditable. |
boolean |
isPathSelected
Returns true if the item identified by the path is currently selected. |
boolean |
isRootVisible
Returns true if the root node of the tree is displayed. |
boolean |
isRowSelected
Returns true if the node identified by row is selected. |
boolean |
isSelectionEmpty
Returns true if the selection is currently empty. |
boolean |
isVisible
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. |
void |
makeVisible
Ensures that the node identified by path is currently viewable. |
protected String |
paramString
Returns a string representation of this JTree. |
protected boolean |
removeDescendantSelectedPaths
Removes any paths in the selection that are descendants of path. |
protected void |
removeDescendantToggledPaths
Removes any descendants of the TreePaths in
toRemove
that have been expanded. |
void |
removeSelectionInterval
Removes the nodes between index0 and index1, inclusive, from the selection. |
void |
removeSelectionPath
Removes the node identified by the specified path from the current selection. |
void |
removeSelectionPaths
Removes the nodes identified by the specified paths from the current selection. |
void |
removeSelectionRow
Removes the row at the index row from the current
selection. |
void |
removeSelectionRows
Removes the rows that are selected at each of the specified rows. |
void |
removeTreeExpansionListener
Removes a listener for TreeExpansion events. |
void |
removeTreeSelectionListener
Removes a TreeSelection listener. |
void |
removeTreeWillExpandListener
Removes a listener for TreeWillExpand events. |
void |
scrollPathToVisible
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. |
void |
scrollRowToVisible
Scrolls the item identified by row until it is displayed. |
void |
setAnchorSelectionPath
Sets the path identified as the anchor. |
void |
setCellEditor
Sets the cell editor. |
void |
setCellRenderer
Sets the TreeCellRenderer that will be used to
draw each cell. |
void |
setDragEnabled
Sets the dragEnabled property,
which must be true to enable
automatic drag handling (the first part of drag and drop)
on this component. |
void |
setEditable
Determines whether the tree is editable. |
protected void |
setExpandedState
Sets the expanded state of this JTree. |
void |
setExpandsSelectedPaths
Configures the expandsSelectedPaths property. |
void |
setInvokesStopCellEditing
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. |
void |
setLargeModel
Specifies whether the UI should use a large model. |
void |
setLeadSelectionPath
Sets the path identifies as the lead. |
void |
setModel
Sets the TreeModel that will provide the data. |
void |
setRootVisible
Determines whether or not the root node from the TreeModel is visible. |
void |
setRowHeight
Sets the height of each cell, in pixels. |
void |
setScrollsOnExpand
Sets the scrollsOnExpand property,
which determines whether the
tree might scroll to show previously hidden children. |
void |
setSelectionInterval
Selects the nodes between index0 and index1, inclusive. |
void |
setSelectionModel
Sets the tree's selection model. |
void |
setSelectionPath
Selects the node identified by the specified path. |
void |
setSelectionPaths
Selects the nodes identified by the specified array of paths. |
void |
setSelectionRow
Selects the node at the specified row in the display. |
void |
setSelectionRows
Selects the nodes corresponding to each of the specified rows in the display. |
void |
setShowsRootHandles
Sets the value of the showsRootHandles property,
which specifies whether the node handles should be displayed. |
void |
setToggleClickCount
Sets the number of mouse clicks before a node will expand or close. |
void |
setUI
Sets the L&F object that renders this component. |
void |
setVisibleRowCount
Sets the number of rows that are to be displayed. |
void |
startEditingAtPath
Selects the node identified by the specified path and initiates editing. |
boolean |
stopEditing
Ends the current editing session. |
void |
treeDidChange
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). |
void |
updateUI
Notification from the UIManager that the L&F has changed. |
Methods inherited from class java.lang.Object ![]() |
|---|
clone |
| Field Detail |
|---|

protected transient TreeModel![]()
![]()
treeModel

protected transient TreeSelectionModel![]()
![]()
selectionModel

protected boolean rootVisible

protected transient TreeCellRenderer![]()
![]()
cellRenderer
null, the UI uses a default
cellRenderer.

protected int rowHeight

protected boolean showsRootHandles
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.
rootVisible


protected transient JTree.TreeSelectionRedirector![]()
![]()
selectionRedirector
selectionListeners.

protected transient TreeCellEditor![]()
![]()
cellEditor
null
(tree is not editable).

protected boolean editable

protected boolean largeModel
This value is only a suggestion to the UI. Not all UIs will take advantage of it. Default value is false.

protected int visibleRowCount
Scrollable interface. It determines the preferred
size of the display area.

protected boolean invokesStopCellEditing
stopCellEditing
is invoked, and changes are saved. If false,
cancelCellEditing is invoked, and changes
are discarded. Default is false.

protected boolean scrollsOnExpand

protected int toggleClickCount

protected transient TreeModelListener![]()
![]()
treeModelListener
expandedState.

public static final String![]()
![]()
CELL_RENDERER_PROPERTY
cellRenderer.

public static final String![]()
![]()
TREE_MODEL_PROPERTY
treeModel.

public static final String![]()
![]()
ROOT_VISIBLE_PROPERTY
rootVisible.

public static final String![]()
![]()
SHOWS_ROOT_HANDLES_PROPERTY
showsRootHandles.

public static final String![]()
![]()
ROW_HEIGHT_PROPERTY
rowHeight.

public static final String![]()
![]()
CELL_EDITOR_PROPERTY
cellEditor.

public static final String![]()
![]()
EDITABLE_PROPERTY
editable.

public static final String![]()
![]()
LARGE_MODEL_PROPERTY
largeModel.

public static final String![]()
![]()
SELECTION_MODEL_PROPERTY

public static final String![]()
![]()
VISIBLE_ROW_COUNT_PROPERTY
visibleRowCount.

public static final String![]()
![]()
INVOKES_STOP_CELL_EDITING_PROPERTY
messagesStopCellEditing.

public static final String![]()
![]()
SCROLLS_ON_EXPAND_PROPERTY
scrollsOnExpand.

public static final String![]()
![]()
TOGGLE_CLICK_COUNT_PROPERTY
toggleClickCount.

public static final String![]()
![]()
LEAD_SELECTION_PATH_PROPERTY
leadSelectionPath.

public static final String![]()
![]()
ANCHOR_SELECTION_PATH_PROPERTY

public static final String![]()
![]()
EXPANDS_SELECTED_PATHS_PROPERTY
| Constructor Detail |
|---|

public JTree()
JTree with a sample model.
The default model used by the tree defines a leaf node as any node
without children.
DefaultTreeModel.asksAllowsChildren


public JTree(Object![]()
![]()
[] value)
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 ObjectsDefaultTreeModel.asksAllowsChildren


public JTree(Vector![]()
![]()
<?> value)
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 VectorDefaultTreeModel.asksAllowsChildren


public JTree(Hashtable![]()
![]()
<?,?> value)
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 HashtableDefaultTreeModel.asksAllowsChildren


public JTree(TreeNode![]()
![]()
root)
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 objectDefaultTreeModel.asksAllowsChildren


public JTree(TreeNode![]()
![]()
root, boolean asksAllowsChildren)
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 objectasksAllowsChildren - if false, any node without children is a
leaf node; if true, only nodes that do not allow
children are leaf nodesDefaultTreeModel.asksAllowsChildren


public JTree(TreeModel![]()
![]()
newModel)
JTree which displays the root node
-- the tree is created using the specified data model.
newModel - the TreeModel to use as the data model| Method Detail |
|---|

protected static TreeModel![]()
![]()
getDefaultTreeModel()
TreeModel.
Used primarily for beanbuilders to show something interesting.
TreeModel

protected static TreeModel![]()
![]()
createTreeModel(Object
![]()
![]()
value)
TreeModel wrapping the specified object.
If the object is:Objects,
Hashtable, or
Vector
value - the Object used as the foundation for
the TreeModel
TreeModel wrapping the specified object

public TreeUI![]()
![]()
getUI()
TreeUI object that renders this component

public void setUI(TreeUI![]()
![]()
ui)
ui - the TreeUI L&F objectUIDefaults.getUI(javax.swing.JComponent)


public void updateUI()
UIManager that the L&F has changed.
Replaces the current UI object with the latest version from the
UIManager.
updateUI

in class JComponent

JComponent.updateUI()


public String![]()
![]()
getUIClassID()
getUIClassID

in class JComponent

JComponent.getUIClassID()
,
UIDefaults.getUI(javax.swing.JComponent)


public TreeCellRenderer![]()
![]()
getCellRenderer()
TreeCellRenderer
that is rendering each cell.
TreeCellRenderer that is rendering each cell

public void setCellRenderer(TreeCellRenderer![]()
![]()
x)
TreeCellRenderer that will be used to
draw each cell.
x - the TreeCellRenderer that is to render each cell

public void setEditable(boolean flag)
flag - a boolean value, true if the tree is editable

public boolean isEditable()

public void setCellEditor(TreeCellEditor![]()
![]()
cellEditor)
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

public TreeCellEditor![]()
![]()
getCellEditor()
TreeCellEditor in use,
or null if the tree cannot be edited

public TreeModel![]()
![]()
getModel()
TreeModel that is providing the data.
TreeModel that is providing the data

public void setModel(TreeModel![]()
![]()
newModel)
TreeModel that will provide the data.
newModel - the TreeModel that is to provide the data

public boolean isRootVisible()
rootVisible


public void setRootVisible(boolean rootVisible)
TreeModel is visible.
rootVisible - true if the root node of the tree is to be displayedrootVisible


public void setShowsRootHandles(boolean newValue)
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, falseshowsRootHandles
,
getShowsRootHandles()


public boolean getShowsRootHandles()
showsRootHandles property.
showsRootHandles propertyshowsRootHandles


public void setRowHeight(int rowHeight)
rowHeight - the height of each cell, in pixels

public int getRowHeight()

public boolean isFixedRowHeight()

public void setLargeModel(boolean newValue)
newValue - true to suggest a large model to the UIlargeModel


public boolean isLargeModel()
largeModel


public void setInvokesStopCellEditing(boolean newValue)
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

public boolean getInvokesStopCellEditing()
setInvokesStopCellEditing(boolean)


public void setScrollsOnExpand(boolean newValue)
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 itgetScrollsOnExpand()


public boolean getScrollsOnExpand()
scrollsOnExpand property.
scrollsOnExpand property

public void setToggleClickCount(int clickCount)

public int getToggleClickCount()

public void setExpandsSelectedPaths(boolean newValue)
expandsSelectedPaths property. If
true, any time the selection is changed, either via the
TreeSelectionModel, or the cover methods provided by
JTree, the TreePaths 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

public boolean getExpandsSelectedPaths()
expandsSelectedPaths property.
setExpandsSelectedPaths(boolean)


public void setDragEnabled(boolean b)
dragEnabled property,
which must be true to enable
automatic drag handling (the first part of drag and drop)
on this component.
The transferHandler property needs to be set
to a non-null value for the drag to do
anything. The default value of the dragEnabled
property
is false.
When automatic drag handling is enabled,
most look and feels begin a drag-and-drop operation
whenever the user presses the mouse button over a selection
and then moves the mouse a few pixels.
Setting this property to true
can therefore have a subtle effect on
how selections behave.
Some look and feels might not support automatic drag and drop;
they will ignore this property. You can work around such
look and feels by modifying the component
to directly call the exportAsDrag method of a
TransferHandler.
b - the value to set the dragEnabled property to
HeadlessException

- if
b is true and
GraphicsEnvironment.isHeadless()
returns trueGraphicsEnvironment.isHeadless()
,
getDragEnabled()
,
JComponent.setTransferHandler(javax.swing.TransferHandler)
,
TransferHandler


public boolean getDragEnabled()
dragEnabled property.
dragEnabled propertysetDragEnabled(boolean)


public boolean isPathEditable(TreePath![]()
![]()
path)
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.
isEditable()


public String![]()
![]()
getToolTipText(MouseEvent
![]()
![]()
event)
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!
getToolTipText

in class JComponent

event - the MouseEvent that initiated the
ToolTip display
null
if event is null

public String![]()
![]()
convertValueToText(Object
![]()
![]()
value, boolean selected, boolean expanded, boolean leaf, int row, boolean hasFocus)
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 textselected - true if the node is selectedexpanded - true if the node is expandedleaf - true if the node is a leaf noderow - an integer specifying the node's display row, where 0 is
the first row in the displayhasFocus - true if the node has the focus
String representation of the node's value

public int getRowCount()

public void setSelectionPath(TreePath![]()
![]()
path)
getExpandsSelectedPaths is true it is
exposed (made viewable).
path - the TreePath specifying the node to select

public void setSelectionPaths(TreePath![]()
![]()
[] paths)
getExpandsSelectedPaths is true
it is exposed (made viewable).
paths - an array of TreePath objects that specifies
the nodes to select

public void setLeadSelectionPath(TreePath![]()
![]()
newPath)
JTree,
rather the UI will update it.
newPath - the new lead path

public void setAnchorSelectionPath(TreePath![]()
![]()
newPath)
JTree, rather the UI will
update it.
newPath - the new anchor path

public void setSelectionRow(int row)
row - the row to select, where 0 is the first row in
the display

public void setSelectionRows(int[] rows)
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

public void addSelectionPath(TreePath![]()
![]()
path)
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

public void addSelectionPaths(TreePath![]()
![]()
[] paths)
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

public void addSelectionRow(int row)
row - an integer specifying the row of the node to add,
where 0 is the first row in the display

public void addSelectionRows(int[] rows)
rows - an array of ints specifying the rows to add,
where 0 indicates the first row in the display

public Object![]()
![]()
getLastSelectedPathComponent()
Object in the first selected node's
TreePath,
or null if nothing is selectedTreePath.getLastPathComponent()


public TreePath![]()
![]()
getLeadSelectionPath()

public TreePath![]()
![]()
getAnchorSelectionPath()

public TreePath![]()
![]()
getSelectionPath()
TreePath for the first selected node,
or null if nothing is currently selected

public TreePath![]()
![]()
[] getSelectionPaths()
TreePath objects indicating the selected
nodes, or null if nothing is currently selected

public int[] getSelectionRows()
TreeSelectionModel.
If nothing is selected null or an empty array will
be returned, based on the TreeSelectionModel
implementation.

public int getSelectionCount()

public int getMinSelectionRow()

public int getMaxSelectionRow()

public int getLeadSelectionRow()
leadPath is null

public boolean isPathSelected(TreePath![]()
![]()
path)
path - a TreePath identifying a node

public boolean isRowSelected(int row)
row - an integer specifying a display row, where 0 is the first
row in the display

public Enumeration![]()
![]()
<TreePath
![]()
![]()
> getExpandedDescendants(TreePath
![]()
![]()
parent)
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

public boolean hasBeenExpanded(TreePath![]()
![]()
path)
path has ever been expanded

public boolean isExpanded(TreePath![]()
![]()
path)
path - the TreePath specifying the node to check

public boolean isExpanded(int row)
row - the row to check, where 0 is the first row in the
display

public boolean isCollapsed(TreePath![]()
![]()
path)
path - the TreePath to check

public boolean isCollapsed(int row)
row - the row to check, where 0 is the first row in the
display

public void makeVisible(TreePath![]()
![]()
path)
path - the TreePath to make visible

public boolean isVisible(TreePath![]()
![]()
path)

public Rectangle![]()
![]()
getPathBounds(TreePath
![]()
![]()
path)
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

public Rectangle![]()
![]()
getRowBounds(int row)
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

public void scrollPathToVisible(TreePath![]()
![]()
path)
JTree is contained in a JScrollPane.
path - the TreePath identifying the node to
bring into view

public void scrollRowToVisible(int row)
JTree is contained in a
JScrollPane.
row - an integer specifying the row to scroll, where 0 is the
first row in the display

public TreePath![]()
![]()
getPathForRow(int row)
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()

public int getRowForPath(TreePath![]()
![]()
path)
path - the TreePath identifying a node

public void expandPath(TreePath![]()
![]()
path)
path - the TreePath identifying a node

public void expandRow(int row)
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

public void collapsePath(TreePath![]()
![]()
path)
path - the TreePath identifying a node

public void collapseRow(int row)
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

public TreePath![]()
![]()
getPathForLocation(int x, int y)
x - an integer giving the number of pixels horizontally from
the left edge of the display area, minus any left marginy - 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

public int getRowForLocation(int x,
int y)
x - an integer giving the number of pixels horizontally from
the left edge of the display area, minus any left marginy - an integer giving the number of pixels vertically from
the top of the display area, minus any top margin
getClosestRowForLocation(int, int)


public TreePath![]()
![]()
getClosestPathForLocation(int x, int y)
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 marginy - 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 modelgetPathForLocation(int, int)
,
getPathBounds(javax.swing.tree.TreePath)


public int getClosestRowForLocation(int x,
int y)
x - an integer giving the number of pixels horizontally from
the left edge of the display area, minus any left marginy - an integer giving the number of pixels vertically from
the top of the display area, minus any top margin
getRowForLocation(int, int)
,
getRowBounds(int)


public boolean isEditing()
getSelectionPath.
getSelectionPath()


public boolean stopEditing()
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)![]()
![]()
.

public void cancelEditing()

public void startEditingAtPath(TreePath![]()
![]()
path)
CellEditor
does not allow
editing for the specified item.
path - the TreePath identifying a node

public TreePath![]()
![]()
getEditingPath()
TreePath for the node being edited

public void setSelectionModel(TreeSelectionModel![]()
![]()
selectionModel)
null value is
specified an emtpy
selectionModel is used, which does not allow selections.
selectionModel - the TreeSelectionModel to use,
or null to disable selectionsTreeSelectionModel


public TreeSelectionModel![]()
![]()
getSelectionModel()
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.
setSelectionModel(javax.swing.tree.TreeSelectionModel)


protected TreePath![]()
![]()
[] getPathBetweenRows(int index0, int index1)
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 displayindex1 - 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

public void setSelectionInterval(int index0,
int index1)
index0 - an integer specifying a display row, where 0 is the
first row in the displayindex1 - an integer specifying a second display row

public void addSelectionInterval(int index0,
int index1)
index0 - an integer specifying a display row, where 0 is the
first row in the displayindex1 - an integer specifying a second display row

public void removeSelectionInterval(int index0,
int index1)
index0 - an integer specifying a display row, where 0 is the
first row in the displayindex1 - an integer specifying a second display row

public void removeSelectionPath(TreePath![]()
![]()
path)
path - the TreePath identifying a node

public void removeSelectionPaths(TreePath![]()
![]()
[] paths)
paths - an array of TreePath objects that
specifies the nodes to remove

public void removeSelectionRow(int row)
row from the current
selection.
row - the row to remove

public void removeSelectionRows(int[] rows)
rows - an array of ints specifying display rows, where 0 is
the first row in the display

public void clearSelection()

public boolean isSelectionEmpty()

public void addTreeExpansionListener(TreeExpansionListener![]()
![]()
tel)
TreeExpansion events.
tel - a TreeExpansionListener that will be notified when
a tree node is expanded or collapsed (a "negative
expansion")

public void removeTreeExpansionListener(TreeExpansionListener![]()
![]()
tel)
TreeExpansion events.
tel - the TreeExpansionListener to remove

public TreeExpansionListener![]()
![]()
[] getTreeExpansionListeners()
TreeExpansionListeners added
to this JTree with addTreeExpansionListener().
TreeExpansionListeners added or an empty
array if no listeners have been added

public void addTreeWillExpandListener(TreeWillExpandListener![]()
![]()
tel)
TreeWillExpand events.
tel - a TreeWillExpandListener that will be notified
when a tree node will be expanded or collapsed (a "negative
expansion")

public void removeTreeWillExpandListener(TreeWillExpandListener![]()
![]()
tel)
TreeWillExpand events.
tel - the TreeWillExpandListener to remove

public TreeWillExpandListener![]()
![]()
[] getTreeWillExpandListeners()
TreeWillExpandListeners added
to this JTree with addTreeWillExpandListener().
TreeWillExpandListeners added or an empty
array if no listeners have been added

public void fireTreeExpanded(TreePath![]()
![]()
path)
path parameter.
path - the TreePath indicating the node that was
expandedEventListenerList


public void fireTreeCollapsed(TreePath![]()
![]()
path)
path parameter.
path - the TreePath indicating the node that was
collapsedEventListenerList


public void fireTreeWillExpand(TreePath![]()
![]()
path) throws ExpandVetoException
![]()
![]()
path parameter.
path - the TreePath indicating the node that was
expanded
ExpandVetoException

EventListenerList


public void fireTreeWillCollapse(TreePath![]()
![]()
path) throws ExpandVetoException
![]()
![]()
path parameter.
path - the TreePath indicating the node that was
expanded
ExpandVetoException

EventListenerList


public void addTreeSelectionListener(TreeSelectionListener![]()
![]()
tsl)
TreeSelection events.
tsl - the TreeSelectionListener that will be notified
when a node is selected or deselected (a "negative
selection")

public void removeTreeSelectionListener(TreeSelectionListener![]()
![]()
tsl)
TreeSelection listener.
tsl - the TreeSelectionListener to remove

public TreeSelectionListener![]()
![]()
[] getTreeSelectionListeners()
TreeSelectionListeners added
to this JTree with addTreeSelectionListener().
TreeSelectionListeners added or an empty
array if no listeners have been added

protected void fireValueChanged(TreeSelectionEvent![]()
![]()
e)
e - the TreeSelectionEvent to be fired;
generated by the
TreeSelectionModel
when a node is selected or deselectedEventListenerList


public void treeDidChange()

public void setVisibleRowCount(int newCount)
JScrollPane,
and will adjust the preferred size and size of that scrollpane.
newCount - the number of rows to display

public int getVisibleRowCount()

public TreePath![]()
![]()
getNextMatch(String
![]()
![]()
prefix, int startingRow, Position.Bias
![]()
![]()
bias)
TreePath into a String, convertValueToText
is used.
prefix - the string to test for a matchstartingRow - the row for starting the searchbias - the search direction, either
Position.Bias.Forward or Position.Bias.Backward.
IllegalArgumentException

- if prefix is null
or startingRow is out of bounds

public Dimension![]()
![]()
getPreferredScrollableViewportSize()
JTree. The height is
determined from getVisibleRowCount and the width
is the current preferred width.
getPreferredScrollableViewportSize

in interface Scrollable

Dimension object containing the preferred sizeJComponent.getPreferredSize()


public int getScrollableUnitIncrement(Rectangle![]()
![]()
visibleRect, int orientation, int direction)
getScrollableUnitIncrement

in interface Scrollable

visibleRect - the view area visible within the viewportorientation - either SwingConstants.VERTICAL
or SwingConstants.HORIZONTALdirection - less than zero to scroll up/left,
greater than zero for down/right
JScrollBar.setUnitIncrement(int)


public int getScrollableBlockIncrement(Rectangle![]()
![]()
visibleRect, int orientation, int direction)
visibleRect, based on orientation.
getScrollableBlockIncrement

in interface Scrollable

visibleRect - the view area visible within the viewportorientation - either SwingConstants.VERTICAL
or SwingConstants.HORIZONTALdirection - less than zero to scroll up/left,
greater than zero for down/right.
JScrollBar.setBlockIncrement(int)


public boolean getScrollableTracksViewportWidth()
getScrollableTracksViewportWidth

in interface Scrollable

Scrollable.getScrollableTracksViewportWidth()


public boolean getScrollableTracksViewportHeight()
getScrollableTracksViewportHeight

in interface Scrollable

Scrollable.getScrollableTracksViewportHeight()


protected void setExpandedState(TreePath![]()
![]()
path, boolean state)
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.

protected Enumeration![]()
![]()
<TreePath
![]()
![]()
> getDescendantToggledPaths(TreePath
![]()
![]()
parent)
Enumeration of TreePaths
that have been expanded that
are descendants of parent.

protected void removeDescendantToggledPaths(Enumeration![]()
![]()
<TreePath
![]()
![]()
> toRemove)
TreePaths in
toRemove
that have been expanded.

protected void clearToggledPaths()
TreeExpansionListener events.

protected TreeModelListener![]()
![]()
createTreeModelListener()
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.

protected boolean removeDescendantSelectedPaths(TreePath![]()
![]()
path, boolean includePath)
path. If includePath is true and
path is selected, it will be removed from the selection.

protected String![]()
![]()
paramString()
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.
paramString

in class JComponent

JTree.

public AccessibleContext![]()
![]()
getAccessibleContext()
getAccessibleContext

in interface Accessible

getAccessibleContext

in class JComponent

|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||