|
JSR-209 (Final Release) | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectjava.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(javax.swing.tree.TreeCellRenderer)
to tell the tree to use it. To edit such nodes,
subclass TreeCellEditor
and use #setCellEditor
.
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 java.beans.XMLEncoder
.
Nested Class Summary | |
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. |
Field Summary | |
static java.lang.String |
ANCHOR_SELECTION_PATH_PROPERTY
Bound property name for anchor selection path. |
static java.lang.String |
CELL_EDITOR_PROPERTY
Bound property name for cellEditor . |
static java.lang.String |
CELL_RENDERER_PROPERTY
Bound property name for cellRenderer . |
protected TreeCellRenderer |
cellRenderer
The cell used to draw nodes. |
protected boolean |
editable
Is the tree editable? Default is false. |
static java.lang.String |
EDITABLE_PROPERTY
Bound property name for editable . |
static java.lang.String |
EXPANDS_SELECTED_PATHS_PROPERTY
Bound property name for expands selected paths property |
static java.lang.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 java.lang.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 java.lang.String |
LEAD_SELECTION_PATH_PROPERTY
Bound property name for leadSelectionPath . |
static java.lang.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 java.lang.String |
ROW_HEIGHT_PROPERTY
Bound property name for rowHeight . |
protected int |
rowHeight
Height to use for each display row. |
static java.lang.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 java.lang.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 java.lang.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 java.lang.String |
TOGGLE_CLICK_COUNT_PROPERTY
Bound property name for toggleClickCount . |
protected int |
toggleClickCount
Number of mouse clicks before a node is expanded. |
static java.lang.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 java.lang.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 |
listenerList, TOOL_TIP_TEXT_KEY, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW |
Fields inherited from class java.awt.Component |
BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT |
Fields inherited from interface java.awt.image.ImageObserver |
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH |
Constructor Summary | |
JTree()
Returns a JTree with a sample model. |
|
JTree(java.util.Hashtable value)
Returns a JTree created from a Hashtable
which does not display with root. |
|
JTree(java.lang.Object[] value)
Returns a JTree with each element of the
specified array as the
child of a new root node which is not displayed. |
|
JTree(TreeModel newModel)
Returns an instance of JTree which displays the root node
-- the tree is created using the specified data model. |
|
JTree(TreeNode root)
Returns a JTree with the specified
TreeNode as its root,
which displays the root node. |
|
JTree(TreeNode root,
boolean asksAllowsChildren)
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(java.util.Vector value)
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(int index0,
int index1)
Adds the paths between index0 and index1, inclusive, to the selection. |
void |
addSelectionPath(TreePath path)
Adds the node identified by the specified TreePath
to the current selection. |
void |
addSelectionPaths(TreePath[] paths)
Adds each path in the array of paths to the current selection. |
void |
addSelectionRow(int row)
Adds the path at the specified row to the current selection. |
void |
addSelectionRows(int[] rows)
Adds the paths at each of the specified rows to the current selection. |
void |
addTreeExpansionListener(TreeExpansionListener tel)
Adds a listener for TreeExpansion events. |
void |
addTreeSelectionListener(TreeSelectionListener tsl)
Adds a listener for TreeSelection events. |
void |
addTreeWillExpandListener(TreeWillExpandListener tel)
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(TreePath path)
Ensures that the node identified by the specified path is collapsed and viewable. |
void |
collapseRow(int row)
Ensures that the node in the specified row is collapsed. |
java.lang.String |
convertValueToText(java.lang.Object value,
boolean selected,
boolean expanded,
boolean leaf,
int row,
boolean hasFocus)
Called by the renderers to convert the specified value to text. |
protected static TreeModel |
createTreeModel(java.lang.Object value)
Returns a TreeModel wrapping the specified object. |
protected TreeModelListener |
createTreeModelListener()
Creates and returns an instance of TreeModelHandler . |
void |
expandPath(TreePath path)
Ensures that the node identified by the specified path is expanded and viewable. |
void |
expandRow(int row)
Ensures that the node in the specified row is expanded and viewable. |
void |
fireTreeCollapsed(TreePath path)
Notifies all listeners that have registered interest for notification on this event type. |
void |
fireTreeExpanded(TreePath path)
Notifies all listeners that have registered interest for notification on this event type. |
void |
fireTreeWillCollapse(TreePath path)
Notifies all listeners that have registered interest for notification on this event type. |
void |
fireTreeWillExpand(TreePath path)
Notifies all listeners that have registered interest for notification on this event type. |
protected void |
fireValueChanged(TreeSelectionEvent e)
Notifies all listeners that have registered interest for notification on this event type. |
TreePath |
getAnchorSelectionPath()
Returns the path identified as the anchor. |
TreeCellRenderer |
getCellRenderer()
Returns the current TreeCellRenderer
that is rendering each cell. |
TreePath |
getClosestPathForLocation(int x,
int y)
Returns the path to the node that is closest to x,y. |
int |
getClosestRowForLocation(int x,
int y)
Returns the row to the node that is closest to x,y. |
protected static TreeModel |
getDefaultTreeModel()
Creates and returns a sample TreeModel . |
protected java.util.Enumeration |
getDescendantToggledPaths(TreePath parent)
Returns an Enumeration of TreePaths
that have been expanded that
are descendants of parent . |
TreePath |
getEditingPath()
Returns the path to the element that is currently being edited. |
java.util.Enumeration |
getExpandedDescendants(TreePath parent)
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. |
java.lang.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(java.lang.String prefix,
int startingRow,
Position.Bias bias)
Returns the TreePath to the next tree element that begins with a prefix. |
protected TreePath[] |
getPathBetweenRows(int index0,
int index1)
Returns JTreePath instances representing the path
between index0 and index1 (including index1). |
Rectangle |
getPathBounds(TreePath path)
Returns the Rectangle that the specified node will be drawn
into. |
TreePath |
getPathForLocation(int x,
int y)
Returns the path for the node at the specified location. |
TreePath |
getPathForRow(int row)
Returns the path for the specified row. |
Dimension |
getPreferredScrollableViewportSize()
Returns the preferred display size of a JTree . |
Rectangle |
getRowBounds(int row)
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(int x,
int y)
Returns the row for the specified location. |
int |
getRowForPath(TreePath path)
Returns the row that displays the node identified by the specified path. |
int |
getRowHeight()
Returns the height of each row. |
int |
getScrollableBlockIncrement(Rectangle visibleRect,
int orientation,
int direction)
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(Rectangle visibleRect,
int orientation,
int direction)
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. |
TreeExpansionListener[] |
getTreeExpansionListeners()
Returns an array of all the TreeExpansionListener s added
to this JTree with addTreeExpansionListener(). |
TreeSelectionListener[] |
getTreeSelectionListeners()
Returns an array of all the TreeSelectionListener s added
to this JTree with addTreeSelectionListener(). |
TreeWillExpandListener[] |
getTreeWillExpandListeners()
Returns an array of all the TreeWillExpandListener s added
to this JTree with addTreeWillExpandListener(). |
int |
getVisibleRowCount()
Returns the number of rows that are displayed in the display area. |
boolean |
hasBeenExpanded(TreePath path)
Returns true if the node identified by the path has ever been expanded. |
boolean |
isCollapsed(int row)
Returns true if the node at the specified display row is collapsed. |
boolean |
isCollapsed(TreePath path)
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(int row)
Returns true if the node at the specified display row is currently expanded. |
boolean |
isExpanded(TreePath path)
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(TreePath path)
Returns isEditable . |
boolean |
isPathSelected(TreePath path)
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(int row)
Returns true if the node identified by row is selected. |
boolean |
isSelectionEmpty()
Returns true if the selection is currently empty. |
boolean |
isVisible(TreePath path)
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(TreePath path)
Ensures that the node identified by path is currently viewable. |
void |
paint(java.awt.Graphics g)
Invoked by Swing to draw components. |
protected void |
paintBorder(java.awt.Graphics g)
Paints the component's border. |
protected void |
paintComponent(java.awt.Graphics g)
Calls the UI delegate's paint method, if the UI delegate is non- null . |
void |
paintComponents(java.awt.Graphics g)
|
protected java.lang.String |
paramString()
Returns a string representation of this JTree . |
protected void |
printBorder(java.awt.Graphics g)
Prints the component's border. |
protected void |
printComponent(java.awt.Graphics g)
This is invoked during a printing operation. |
void |
printComponents(java.awt.Graphics g)
|
protected boolean |
removeDescendantSelectedPaths(TreePath path,
boolean includePath)
Removes any paths in the selection that are descendants of path . |
protected void |
removeDescendantToggledPaths(java.util.Enumeration toRemove)
Removes any descendants of the TreePaths in
toRemove
that have been expanded. |
void |
removeSelectionInterval(int index0,
int index1)
Removes the nodes between index0 and index1, inclusive, from the selection. |
void |
removeSelectionPath(TreePath path)
Removes the node identified by the specified path from the current selection. |
void |
removeSelectionPaths(TreePath[] paths)
Removes the nodes identified by the specified paths from the current selection. |
void |
removeSelectionRow(int row)
Removes the row at the index row from the current
selection. |
void |
removeSelectionRows(int[] rows)
Removes the rows that are selected at each of the specified rows. |
void |
removeTreeExpansionListener(TreeExpansionListener tel)
Removes a listener for TreeExpansion events. |
void |
removeTreeSelectionListener(TreeSelectionListener tsl)
Removes a TreeSelection listener. |
void |
removeTreeWillExpandListener(TreeWillExpandListener tel)
Removes a listener for TreeWillExpand events. |
void |
scrollPathToVisible(TreePath path)
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(int row)
Scrolls the item identified by row until it is displayed. |
void |
setAnchorSelectionPath(TreePath newPath)
Sets the path identified as the anchor. |
void |
setCellRenderer(TreeCellRenderer x)
Sets the TreeCellRenderer that will be used to
draw each cell. |
void |
setEditable(boolean flag)
Determines whether the tree is editable. |
protected void |
setExpandedState(TreePath path,
boolean state)
Sets the expanded state of this JTree . |
void |
setExpandsSelectedPaths(boolean newValue)
Configures the expandsSelectedPaths property. |
void |
setInvokesStopCellEditing(boolean newValue)
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(boolean newValue)
Specifies whether the UI should use a large model. |
void |
setLeadSelectionPath(TreePath newPath)
Sets the path identifies as the lead. |
void |
setModel(TreeModel newModel)
Sets the TreeModel that will provide the data. |
void |
setRootVisible(boolean rootVisible)
Determines whether or not the root node from the TreeModel is visible. |
void |
setRowHeight(int rowHeight)
Sets the height of each cell, in pixels. |
void |
setScrollsOnExpand(boolean newValue)
Sets the scrollsOnExpand property,
which determines whether the
tree might scroll to show previously hidden children. |
void |
setSelectionInterval(int index0,
int index1)
Selects the nodes between index0 and index1, inclusive. |
void |
setSelectionModel(TreeSelectionModel selectionModel)
Sets the tree's selection model. |
void |
setSelectionPath(TreePath path)
Selects the node identified by the specified path. |
void |
setSelectionPaths(TreePath[] paths)
Selects the nodes identified by the specified array of paths. |
void |
setSelectionRow(int row)
Selects the node at the specified row in the display. |
void |
setSelectionRows(int[] rows)
Selects the nodes corresponding to each of the specified rows in the display. |
void |
setShowsRootHandles(boolean newValue)
Sets the value of the showsRootHandles property,
which specifies whether the node handles should be displayed. |
void |
setToggleClickCount(int clickCount)
Sets the number of mouse clicks before a node will expand or close. |
void |
setVisibleRowCount(int newCount)
Sets the number of rows that are to be displayed. |
void |
startEditingAtPath(TreePath path)
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). |
Methods inherited from class java.awt.Container |
add, add, add, add, add, addContainerListener, addImpl, areFocusTraversalKeysSet, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getContainerListeners, getFocusTraversalKeys, getFocusTraversalPolicy, getLayout, invalidate, isAncestorOf, isFocusCycleRoot, isFocusCycleRoot, isFocusTraversalPolicySet, list, list, processContainerEvent, processEvent, remove, remove, removeAll, removeContainerListener, setFocusCycleRoot, setFocusTraversalKeys, setFocusTraversalPolicy, setLayout, transferFocusBackward, transferFocusDownCycle, validate, validateTree |
Methods inherited from class java.awt.Component |
addComponentListener, addFocusListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enableEvents, enableInputMethods, getBackground, getBounds, getColorModel, getComponentListeners, getCursor, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getFontMetrics, getForeground, getGraphicsConfiguration, getIgnoreRepaint, getInputContext, getInputMethodListeners, getInputMethodRequests, getKeyListeners, getLocale, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMouseWheelListeners, getName, getParent, getSize, getToolkit, getTreeLock, hasFocus, imageUpdate, isBackgroundSet, isCursorSet, isDisplayable, isEnabled, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isShowing, isValid, isVisible, list, list, list, paintAll, prepareImage, prepareImage, processComponentEvent, processFocusEvent, processInputMethodEvent, processMouseEvent, processMouseWheelEvent, removeComponentListener, removeFocusListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, repaint, repaint, repaint, setBounds, setBounds, setCursor, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setName, setSize, setSize, toString, transferFocus, transferFocusUpCycle |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
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 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 java.lang.String CELL_RENDERER_PROPERTY
cellRenderer
.
public static final java.lang.String TREE_MODEL_PROPERTY
treeModel
.
public static final java.lang.String ROOT_VISIBLE_PROPERTY
rootVisible
.
public static final java.lang.String SHOWS_ROOT_HANDLES_PROPERTY
showsRootHandles
.
public static final java.lang.String ROW_HEIGHT_PROPERTY
rowHeight
.
public static final java.lang.String CELL_EDITOR_PROPERTY
cellEditor
.
public static final java.lang.String EDITABLE_PROPERTY
editable
.
public static final java.lang.String LARGE_MODEL_PROPERTY
largeModel
.
public static final java.lang.String SELECTION_MODEL_PROPERTY
public static final java.lang.String VISIBLE_ROW_COUNT_PROPERTY
visibleRowCount
.
public static final java.lang.String INVOKES_STOP_CELL_EDITING_PROPERTY
messagesStopCellEditing
.
public static final java.lang.String SCROLLS_ON_EXPAND_PROPERTY
scrollsOnExpand
.
public static final java.lang.String TOGGLE_CLICK_COUNT_PROPERTY
toggleClickCount
.
public static final java.lang.String LEAD_SELECTION_PATH_PROPERTY
leadSelectionPath
.
public static final java.lang.String ANCHOR_SELECTION_PATH_PROPERTY
public static final java.lang.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(java.lang.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 Object
sDefaultTreeModel.asksAllowsChildren
public JTree(java.util.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 Vector
DefaultTreeModel.asksAllowsChildren
public JTree(java.util.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 Hashtable
DefaultTreeModel.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 modelMethod Detail |
protected static TreeModel getDefaultTreeModel()
TreeModel
.
Used primarily for beanbuilders to show something interesting.
TreeModel
protected static TreeModel createTreeModel(java.lang.Object value)
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 objectpublic final void paint(java.awt.Graphics g)
JComponent
paint
directly,
but should instead use the repaint
method to
schedule the component for redrawing.
This method actually delegates the work of painting to three
protected methods: paintComponent
,
paintBorder
,
and paintChildren
. They're called in the order
listed to ensure that children appear on top of component itself.
Generally speaking, the component and its children should not
paint in the insets area allocated to the border. Subclasses can
just override this method, as always.
paint
in class JComponent
g
- the Graphics
context in which to paintJComponent.paintBorder(java.awt.Graphics)
,
JComponent.paintChildren(java.awt.Graphics)
,
JComponent.getComponentGraphics(java.awt.Graphics)
,
JComponent.repaint(long, int, int, int, int)
public TreeCellRenderer getCellRenderer()
TreeCellRenderer
that is rendering each cell.
TreeCellRenderer
that is rendering each cellpublic void setCellRenderer(TreeCellRenderer x)
TreeCellRenderer
that will be used to
draw each cell.
x
- the TreeCellRenderer
that is to render each cellpublic void setEditable(boolean flag)
flag
- a boolean value, true if the tree is editablepublic boolean isEditable()
public TreeModel getModel()
TreeModel
that is providing the data.
TreeModel
that is providing the datapublic void setModel(TreeModel newModel)
TreeModel
that will provide the data.
newModel
- the TreeModel
that is to provide the datapublic 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, false
showsRootHandles
,
getShowsRootHandles()
public boolean getShowsRootHandles()
showsRootHandles
property.
showsRootHandles
propertyshowsRootHandles
public void setRowHeight(int rowHeight)
rowHeight
- the height of each cell, in pixelspublic 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 lostpublic 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
propertypublic 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 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
public boolean getExpandsSelectedPaths()
expandsSelectedPaths
property.
setExpandsSelectedPaths(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 java.lang.String convertValueToText(java.lang.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 valuepublic int getRowCount()
public void setSelectionPath(TreePath path)
getExpandsSelectedPaths
is true it is
exposed (made viewable).
path
- the TreePath
specifying the node to selectpublic void setSelectionPaths(TreePath[] paths)
getExpandsSelectedPaths
is true
it is exposed (made viewable).
paths
- an array of TreePath
objects that specifies
the nodes to selectpublic void setLeadSelectionPath(TreePath newPath)
JTree
,
rather the UI will update it.
newPath
- the new lead pathpublic void setAnchorSelectionPath(TreePath newPath)
JTree
, rather the UI will
update it.
newPath
- the new anchor pathpublic void setSelectionRow(int row)
row
- the row to select, where 0 is the first row in
the displaypublic 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 displaypublic 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 addpublic 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 addpublic void addSelectionRow(int row)
row
- an integer specifying the row of the node to add,
where 0 is the first row in the displaypublic void addSelectionRows(int[] rows)
rows
- an array of ints specifying the rows to add,
where 0 indicates the first row in the displaypublic java.lang.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 selectedpublic TreePath[] getSelectionPaths()
TreePath
objects indicating the selected
nodes, or null
if nothing is currently selectedpublic 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 java.util.Enumeration 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 expandedpublic boolean hasBeenExpanded(TreePath path)
path
has ever been expandedpublic 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 visiblepublic 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 inpublic void scrollPathToVisible(TreePath path)
JTree
is contained in a JScrollPane
.
path
- the TreePath
identifying the node to
bring into viewpublic 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 displaypublic 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 nodepublic 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 displaypublic void collapsePath(TreePath path)
path
- the TreePath
identifying a nodepublic 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 displaypublic 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 locationpublic 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 nodepublic TreePath getEditingPath()
TreePath
for the node being editedpublic 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 treepublic 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 rowpublic 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 rowpublic 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 rowpublic void removeSelectionPath(TreePath path)
path
- the TreePath
identifying a nodepublic void removeSelectionPaths(TreePath[] paths)
paths
- an array of TreePath
objects that
specifies the nodes to removepublic void removeSelectionRow(int row)
row
from the current
selection.
row
- the row to removepublic void removeSelectionRows(int[] rows)
rows
- an array of ints specifying display rows, where 0 is
the first row in the displaypublic 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 removepublic TreeExpansionListener[] getTreeExpansionListeners()
TreeExpansionListener
s added
to this JTree with addTreeExpansionListener().
TreeExpansionListener
s added or an empty
array if no listeners have been addedpublic 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 removepublic TreeWillExpandListener[] getTreeWillExpandListeners()
TreeWillExpandListener
s added
to this JTree with addTreeWillExpandListener().
TreeWillExpandListener
s added or an empty
array if no listeners have been addedpublic 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 removepublic TreeSelectionListener[] getTreeSelectionListeners()
TreeSelectionListener
s added
to this JTree with addTreeSelectionListener().
TreeSelectionListener
s added or an empty
array if no listeners have been addedprotected 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 displaypublic int getVisibleRowCount()
public TreePath getNextMatch(java.lang.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.
java.lang.IllegalArgumentException
- if prefix is null
or startingRow is out of boundspublic 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.HORIZONTAL
direction
- 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.HORIZONTAL
direction
- 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 java.util.Enumeration getDescendantToggledPaths(TreePath parent)
Enumeration
of TreePaths
that have been expanded that
are descendants of parent
.
protected void removeDescendantToggledPaths(java.util.Enumeration 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 java.lang.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
.protected final void paintComponent(java.awt.Graphics g)
JComponent
null
. We pass the delegate a copy of the
Graphics
object to protect the rest of the
paint code from irrevocable changes
(for example, Graphics.translate
).
paintComponent
in class JComponent
g
- the Graphics
object to protectJComponent.paint(java.awt.Graphics)
,
ComponentUI
protected final void paintBorder(java.awt.Graphics g)
JComponent
paintBorder
in class JComponent
g
- the Graphics
context in which to paintJComponent.paint(java.awt.Graphics)
,
JComponent.setBorder(javax.swing.border.Border)
public final void paintComponents(java.awt.Graphics g)
protected final void printComponent(java.awt.Graphics g)
JComponent
paintComponent
on the component.
printComponent
in class JComponent
g
- the Graphics
context in which to paintJComponent.print(java.awt.Graphics)
protected final void printBorder(java.awt.Graphics g)
JComponent
paintBorder
on the component.
printBorder
in class JComponent
g
- the Graphics
context in which to paintJComponent.print(java.awt.Graphics)
public final void printComponents(java.awt.Graphics g)
|
JSR-209 (Final Release) | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |