Class JTree
- All Implemented Interfaces:
-
ImageObserver,MenuContainer,Serializable,Accessible,Scrollable
@JavaBean(defaultProperty="UI", description="A component that displays a set of hierarchical data as an outline.") public class JTree extends JComponent implements Scrollable, Accessible
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.
JTree methods use "visible" to mean "displayed": -
isRootVisible() -
setRootVisible() -
scrollPathToVisible() -
scrollRowToVisible() -
getVisibleRowCount() -
setVisibleRowCount()
JTree methods use "visible" to mean "viewable" (under an expanded parent): -
isVisible() -
makeVisible()
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 JavaBeans has been added to the java.beans package. Please see XMLEncoder.
- Since:
- 1.2
Nested Class Summary
| Modifier and Type | Class | Description |
|---|---|---|
protected class |
JTree.AccessibleJTree |
This class implements accessibility support for the JTree class. |
static final class |
JTree.DropLocation |
A subclass of TransferHandler.DropLocation representing a drop location for a JTree. |
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 declared in class javax.swing.JComponent
JComponent.AccessibleJComponent
Nested classes/interfaces declared in class java.awt.Container
Container.AccessibleAWTContainer
Nested classes/interfaces declared in class java.awt.Component
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
Field Summary
| Modifier and Type | Field | Description |
|---|---|---|
static final String |
ANCHOR_SELECTION_PATH_PROPERTY |
Bound property name for anchor selection path. |
static final String |
CELL_EDITOR_PROPERTY |
Bound property name for cellEditor. |
static final 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? |
static final String |
EDITABLE_PROPERTY |
Bound property name for editable. |
static final String |
EXPANDS_SELECTED_PATHS_PROPERTY |
Bound property name for expands selected paths property |
static final 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 final String |
LARGE_MODEL_PROPERTY |
Bound property name for largeModel. |
protected boolean |
largeModel |
Is this tree a large model? |
static final String |
LEAD_SELECTION_PATH_PROPERTY |
Bound property name for leadSelectionPath. |
static final 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 final String |
ROW_HEIGHT_PROPERTY |
Bound property name for rowHeight. |
protected int |
rowHeight |
Height to use for each display row. |
static final 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 final 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 final 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 final String |
TOGGLE_CLICK_COUNT_PROPERTY |
Bound property name for toggleClickCount. |
protected int |
toggleClickCount |
Number of mouse clicks before a node is expanded. |
static final 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 final String |
VISIBLE_ROW_COUNT_PROPERTY |
Bound property name for visibleRowCount. |
protected int |
visibleRowCount |
Number of rows to make visible at one time. |
Fields declared in class javax.swing.JComponent
listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW
Fields declared in class java.awt.Component
accessibleContext, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT
Fields declared in interface java.awt.image.ImageObserver
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
Constructor Summary
| Constructor | Description |
|---|---|
JTree() |
Returns a JTree with a sample model. |
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 a JTree created from a Hashtable which does not display with root. |
JTree |
Returns a JTree with each element of the specified Vector 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. |
Method Summary
| Modifier and Type | Method | Description |
|---|---|---|
void |
addSelectionInterval |
Adds the specified rows (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<TreePath> |
getDescendantToggledPaths |
Returns an Enumeration of TreePaths that have been expanded that are descendants of parent. |
boolean |
getDragEnabled() |
Returns whether or not automatic drag handling is enabled. |
final JTree.DropLocation |
getDropLocation() |
Returns the location that this component should visually indicate as the drop location during a DnD operation over the component, or null if no location is to currently be shown. |
final DropMode |
getDropMode() |
Returns the drop mode for this component. |
TreePath |
getEditingPath() |
Returns the path to the element that is currently being edited. |
Enumeration<TreePath> |
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 of the selected path. |
TreePath |
getLeadSelectionPath() |
Returns the path identified as the lead. |
int |
getLeadSelectionRow() |
Returns the row index corresponding to the lead path. |
int |
getMaxSelectionRow() |
Returns the largest selected row. |
int |
getMinSelectionRow() |
Returns the smallest 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 the paths (inclusive) between the specified rows. |
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 viewable nodes. |
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 specified rows (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 |
Turns on or off automatic drag handling. |
final void |
setDropMode |
Sets the drop mode for 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 rows in the specified interval (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 declared in class javax.swing.JComponent
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, firePropertyChange, firePropertyChange, fireVetoableChange, getActionForKeyStroke, getActionMap, getAlignmentX, getAlignmentY, getAncestorListeners, getAutoscrolls, getBaseline, getBaselineResizeBehavior, getBorder, getBounds, getClientProperty, getComponentGraphics, getComponentPopupMenu, getConditionForKeyStroke, getDebugGraphicsOptions, getDefaultLocale, getFontMetrics, getGraphics, getHeight, getInheritsPopupMenu, getInputMap, getInputMap, getInputVerifier, getInsets, getInsets, getListeners, getLocation, getMaximumSize, getMinimumSize, getNextFocusableComponent, getPopupLocation, getPreferredSize, getRegisteredKeyStrokes, getRootPane, getSize, getToolTipLocation, getToolTipText, getTopLevelAncestor, getTransferHandler, getVerifyInputWhenFocusTarget, getVetoableChangeListeners, getVisibleRect, getWidth, getX, getY, grabFocus, hide, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, isPaintingForPrint, isPaintingOrigin, isPaintingTile, isRequestFocusEnabled, isValidateRoot, paint, paintBorder, paintChildren, paintComponent, paintImmediately, paintImmediately, print, printAll, printBorder, printChildren, printComponent, processComponentKeyEvent, processKeyBinding, processKeyEvent, processMouseEvent, processMouseMotionEvent, putClientProperty, registerKeyboardAction, registerKeyboardAction, removeAncestorListener, removeNotify, removeVetoableChangeListener, repaint, repaint, requestDefaultFocus, requestFocus, requestFocus, requestFocusInWindow, requestFocusInWindow, resetKeyboardActions, reshape, revalidate, scrollRectToVisible, setActionMap, setAlignmentX, setAlignmentY, setAutoscrolls, setBackground, setBorder, setComponentPopupMenu, setDebugGraphicsOptions, setDefaultLocale, setDoubleBuffered, setEnabled, setFocusTraversalKeys, setFont, setForeground, setInheritsPopupMenu, setInputMap, setInputVerifier, setMaximumSize, setMinimumSize, setNextFocusableComponent, setOpaque, setPreferredSize, setRequestFocusEnabled, setToolTipText, setTransferHandler, setUI, setVerifyInputWhenFocusTarget, setVisible, unregisterKeyboardAction, update
Methods declared in class java.awt.Container
add, add, add, add, add, addContainerListener, addImpl, addPropertyChangeListener, addPropertyChangeListener, applyComponentOrientation, areFocusTraversalKeysSet, countComponents, deliverEvent, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getComponentZOrder, getContainerListeners, getFocusTraversalKeys, getFocusTraversalPolicy, getLayout, getMousePosition, insets, invalidate, isAncestorOf, isFocusCycleRoot, isFocusCycleRoot, isFocusTraversalPolicyProvider, isFocusTraversalPolicySet, layout, list, list, locate, minimumSize, paintComponents, preferredSize, printComponents, processContainerEvent, processEvent, remove, remove, removeAll, removeContainerListener, setComponentZOrder, setFocusCycleRoot, setFocusTraversalPolicy, setFocusTraversalPolicyProvider, setLayout, transferFocusDownCycle, validate, validateTree
Methods declared in class java.awt.Component
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, bounds, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enable, enableEvents, enableInputMethods, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getBackground, getBounds, getColorModel, getComponentListeners, getComponentOrientation, getCursor, getDropTarget, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getForeground, getGraphicsConfiguration, getHierarchyBoundsListeners, getHierarchyListeners, getIgnoreRepaint, getInputContext, getInputMethodListeners, getInputMethodRequests, getKeyListeners, getLocale, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMousePosition, getMouseWheelListeners, getName, getParent, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getToolkit, getTreeLock, gotFocus, handleEvent, hasFocus, imageUpdate, inside, isBackgroundSet, isCursorSet, isDisplayable, isEnabled, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isMaximumSizeSet, isMinimumSizeSet, isPreferredSizeSet, isShowing, isValid, isVisible, keyDown, keyUp, list, list, list, location, lostFocus, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paintAll, postEvent, prepareImage, prepareImage, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processInputMethodEvent, processMouseWheelEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, requestFocus, requestFocus, requestFocusInWindow, resize, resize, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setMixingCutoutShape, setName, setSize, setSize, show, show, size, toString, transferFocus, transferFocusBackward, transferFocusUpCycle
Field Details
treeModel
protected transient TreeModel treeModel
selectionModel
protected transient TreeSelectionModel selectionModel
rootVisible
protected boolean rootVisible
cellRenderer
protected transient TreeCellRenderer cellRenderer
null, the UI uses a default cellRenderer.rowHeight
protected int rowHeight
showsRootHandles
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.
- See Also:
selectionRedirector
protected transient JTree.TreeSelectionRedirector selectionRedirector
selectionListeners.cellEditor
protected transient TreeCellEditor cellEditor
null (tree is not editable).editable
protected boolean editable
largeModel
protected boolean largeModel
This value is only a suggestion to the UI. Not all UIs will take advantage of it. Default value is false.
visibleRowCount
protected int visibleRowCount
Scrollable interface. It determines the preferred size of the display area.invokesStopCellEditing
protected boolean invokesStopCellEditing
stopCellEditing is invoked, and changes are saved. If false, cancelCellEditing is invoked, and changes are discarded. Default is false.scrollsOnExpand
protected boolean scrollsOnExpand
toggleClickCount
protected int toggleClickCount
treeModelListener
protected transient TreeModelListener treeModelListener
expandedState.CELL_RENDERER_PROPERTY
public static final String CELL_RENDERER_PROPERTY
cellRenderer.- See Also:
TREE_MODEL_PROPERTY
public static final String TREE_MODEL_PROPERTY
treeModel.- See Also:
ROOT_VISIBLE_PROPERTY
public static final String ROOT_VISIBLE_PROPERTY
rootVisible.- See Also:
SHOWS_ROOT_HANDLES_PROPERTY
public static final String SHOWS_ROOT_HANDLES_PROPERTY
showsRootHandles.- See Also:
ROW_HEIGHT_PROPERTY
public static final String ROW_HEIGHT_PROPERTY
rowHeight.- See Also:
CELL_EDITOR_PROPERTY
public static final String CELL_EDITOR_PROPERTY
cellEditor.- See Also:
EDITABLE_PROPERTY
public static final String EDITABLE_PROPERTY
editable.- See Also:
LARGE_MODEL_PROPERTY
public static final String LARGE_MODEL_PROPERTY
largeModel.- See Also:
SELECTION_MODEL_PROPERTY
public static final String SELECTION_MODEL_PROPERTY
- See Also:
VISIBLE_ROW_COUNT_PROPERTY
public static final String VISIBLE_ROW_COUNT_PROPERTY
visibleRowCount.- See Also:
INVOKES_STOP_CELL_EDITING_PROPERTY
public static final String INVOKES_STOP_CELL_EDITING_PROPERTY
messagesStopCellEditing.- See Also:
SCROLLS_ON_EXPAND_PROPERTY
public static final String SCROLLS_ON_EXPAND_PROPERTY
scrollsOnExpand.- See Also:
TOGGLE_CLICK_COUNT_PROPERTY
public static final String TOGGLE_CLICK_COUNT_PROPERTY
toggleClickCount.- See Also:
LEAD_SELECTION_PATH_PROPERTY
public static final String LEAD_SELECTION_PATH_PROPERTY
leadSelectionPath.- Since:
- 1.3
- See Also:
ANCHOR_SELECTION_PATH_PROPERTY
public static final String ANCHOR_SELECTION_PATH_PROPERTY
- Since:
- 1.3
- See Also:
EXPANDS_SELECTED_PATHS_PROPERTY
public static final String EXPANDS_SELECTED_PATHS_PROPERTY
- Since:
- 1.3
- See Also:
Constructor Details
JTree
public JTree()
JTree with a sample model. The default model used by the tree defines a leaf node as any node without children.- See Also:
JTree
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.- Parameters:
-
value- an array ofObjects - See Also:
JTree
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.- Parameters:
-
value- aVector - See Also:
JTree
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.- Parameters:
-
value- aHashtable - See Also:
JTree
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.- Parameters:
-
root- aTreeNodeobject - See Also:
JTree
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.- Parameters:
-
root- aTreeNodeobject -
asksAllowsChildren- if false, any node without children is a leaf node; if true, only nodes that do not allow children are leaf nodes - See Also:
JTree
@ConstructorProperties("model") public JTree(TreeModel newModel) JTree which displays the root node -- the tree is created using the specified data model.- Parameters:
-
newModel- theTreeModelto use as the data model
Method Details
getDefaultTreeModel
protected static TreeModel getDefaultTreeModel()
TreeModel. Used primarily for beanbuilders to show something interesting.- Returns:
- the default
TreeModel
createTreeModel
protected static TreeModel createTreeModel(Object value)
TreeModel wrapping the specified object. If the object is:- an array of
Objects, - a
Hashtable, or - a
Vector
"root".- Parameters:
-
value- theObjectused as the foundation for theTreeModel - Returns:
- a
TreeModelwrapping the specified object
getUI
public TreeUI getUI()
- Overrides:
-
getUIin classJComponent - Returns:
- the
TreeUIobject that renders this component
setUI
@BeanProperty(hidden=true, visualUpdate=true, description="The UI object that implements the Component\'s LookAndFeel.") public void setUI(TreeUI ui)
This is a bound property.
- Parameters:
-
ui- theTreeUIL&F object - See Also:
updateUI
public void updateUI()
UIManager that the L&F has changed. Replaces the current UI object with the latest version from the UIManager.- Overrides:
-
updateUIin classJComponent - See Also:
getUIClassID
@BeanProperty(bound=false) public String getUIClassID()
- Overrides:
-
getUIClassIDin classJComponent - Returns:
- the string "TreeUI"
- See Also:
getCellRenderer
public TreeCellRenderer getCellRenderer()
TreeCellRenderer that is rendering each cell.- Returns:
- the
TreeCellRendererthat is rendering each cell
setCellRenderer
@BeanProperty(description="The TreeCellRenderer that will be used to draw each cell.") public void setCellRenderer(TreeCellRenderer x)
TreeCellRenderer that will be used to draw each cell. This is a bound property.
- Parameters:
-
x- theTreeCellRendererthat is to render each cell
setEditable
@BeanProperty(description="Whether the tree is editable.") public void setEditable(boolean flag)
This is a bound property.
- Parameters:
-
flag- a boolean value, true if the tree is editable
isEditable
public boolean isEditable()
- Returns:
- true if the tree is editable
setCellEditor
@BeanProperty(description="The cell editor. A null value implies the tree cannot be edited.") 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. This is a bound property.
- Parameters:
-
cellEditor- theTreeCellEditorto use
getCellEditor
public TreeCellEditor getCellEditor()
- Returns:
- the
TreeCellEditorin use, ornullif the tree cannot be edited
getModel
public TreeModel getModel()
TreeModel that is providing the data.- Returns:
- the
TreeModelthat is providing the data
setModel
@BeanProperty(description="The TreeModel that will provide the data.") public void setModel(TreeModel newModel)
TreeModel that will provide the data. This is a bound property.
- Parameters:
-
newModel- theTreeModelthat is to provide the data
isRootVisible
public boolean isRootVisible()
- Returns:
- true if the root node of the tree is displayed
- See Also:
setRootVisible
@BeanProperty(description="Whether or not the root node from the TreeModel is visible.") public void setRootVisible(boolean rootVisible)
TreeModel is visible. This is a bound property.
- Parameters:
-
rootVisible- true if the root node of the tree is to be displayed - See Also:
setShowsRootHandles
@BeanProperty(description="Whether the node handles are to be displayed.") 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. This is a bound property.
- Parameters:
-
newValue-trueif root handles should be displayed; otherwise,false - See Also:
getShowsRootHandles
public boolean getShowsRootHandles()
showsRootHandles property.- Returns:
- the value of the
showsRootHandlesproperty - See Also:
setRowHeight
@BeanProperty(description="The height of each cell.") public void setRowHeight(int rowHeight)
This is a bound property.
- Parameters:
-
rowHeight- the height of each cell, in pixels
getRowHeight
public int getRowHeight()
- Returns:
- the height of each row
isFixedRowHeight
@BeanProperty(bound=false) public boolean isFixedRowHeight()
- Returns:
- true if the height of each row is a fixed size
setLargeModel
@BeanProperty(description="Whether the UI should use a large model.") public void setLargeModel(boolean newValue)
This is a bound property.
- Parameters:
-
newValue- true to suggest a large model to the UI - See Also:
isLargeModel
public boolean isLargeModel()
- Returns:
- true if a large model is suggested
- See Also:
setInvokesStopCellEditing
@BeanProperty(description="Determines what happens when editing is interrupted, selecting another node in the tree, a change in the tree\'s data, or some other means.") 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.
- Parameters:
-
newValue- true means thatstopCellEditingis invoked when editing is interrupted, and data is saved; false means thatcancelCellEditingis invoked, and changes are lost
getInvokesStopCellEditing
public boolean getInvokesStopCellEditing()
- Returns:
- the indicator that tells what happens when editing is interrupted
- See Also:
setScrollsOnExpand
@BeanProperty(description="Indicates if a node descendant should be scrolled when expanded.") 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. This is a bound property.
- Parameters:
-
newValue-falseto disable scrolling on expansion;trueto enable it - See Also:
getScrollsOnExpand
public boolean getScrollsOnExpand()
scrollsOnExpand property.- Returns:
- the value of the
scrollsOnExpandproperty
setToggleClickCount
@BeanProperty(description="Number of clicks before a node will expand/collapse.") public void setToggleClickCount(int clickCount)
This is a bound property.
- Parameters:
-
clickCount- the number of mouse clicks to get a node expanded or closed - Since:
- 1.3
getToggleClickCount
public int getToggleClickCount()
- Returns:
- number of mouse clicks before node is expanded
- Since:
- 1.3
setExpandsSelectedPaths
@BeanProperty(description="Indicates whether changes to the selection should make the parent of the path visible.") 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). This is a bound property.
- Parameters:
-
newValue- the new value forexpandsSelectedPaths - Since:
- 1.3
getExpandsSelectedPaths
public boolean getExpandsSelectedPaths()
expandsSelectedPaths property.- Returns:
- true if selection changes result in the parent path being expanded
- Since:
- 1.3
- See Also:
setDragEnabled
@BeanProperty(bound=false, description="determines whether automatic drag handling is enabled") public void setDragEnabled(boolean b)
true, and the tree's TransferHandler needs to be non-null. The default value of the dragEnabled property is false. The job of honoring this property, and recognizing a user drag gesture, lies with the look and feel implementation, and in particular, the tree's TreeUI. When automatic drag handling is enabled, most look and feels (including those that subclass BasicLookAndFeel) begin a drag and drop operation whenever the user presses the mouse button over an item and then moves the mouse a few pixels. Setting this property to true can therefore have a subtle effect on how selections behave.
If a look and feel is used that ignores this property, you can still begin a drag and drop operation by calling exportAsDrag on the tree's TransferHandler.
- Parameters:
-
b- whether or not to enable automatic drag handling - Throws:
-
HeadlessException- ifbistrueandGraphicsEnvironment.isHeadless()returnstrue - Since:
- 1.4
- See Also:
getDragEnabled
public boolean getDragEnabled()
- Returns:
- the value of the
dragEnabledproperty - Since:
- 1.4
- See Also:
setDropMode
public final void setDropMode(DropMode dropMode)
DropMode.USE_SELECTION. Usage of one of the other modes is recommended, however, for an improved user experience. DropMode.ON, for instance, offers similar behavior of showing items as selected, but does so without affecting the actual selection in the tree. JTree supports the following drop modes:
DropMode.USE_SELECTIONDropMode.ONDropMode.INSERTDropMode.ON_OR_INSERT
The drop mode is only meaningful if this component has a TransferHandler that accepts drops.
- Parameters:
-
dropMode- the drop mode to use - Throws:
-
IllegalArgumentException- if the drop mode is unsupported ornull - Since:
- 1.6
- See Also:
getDropMode
public final DropMode getDropMode()
- Returns:
- the drop mode for this component
- Since:
- 1.6
- See Also:
getDropLocation
@BeanProperty(bound=false) public final JTree.DropLocation getDropLocation()
null if no location is to currently be shown. This method is not meant for querying the drop location from a TransferHandler, as the drop location is only set after the TransferHandler's canImport has returned and has allowed for the location to be shown.
When this property changes, a property change event with name "dropLocation" is fired by the component.
- Returns:
- the drop location
- Since:
- 1.6
- See Also:
isPathEditable
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.- Parameters:
-
path- aTreePathidentifying a node - Returns:
- true if every parent node and the node itself is editable
- See Also:
getToolTipText
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!
- Overrides:
-
getToolTipTextin classJComponent - Parameters:
-
event- theMouseEventthat initiated theToolTipdisplay - Returns:
- a string containing the tooltip or
nullifeventis null
convertValueToText
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.- Parameters:
-
value- theObjectto convert to text -
selected- true if the node is selected -
expanded- true if the node is expanded -
leaf- true if the node is a leaf node -
row- an integer specifying the node's display row, where 0 is the first row in the display -
hasFocus- true if the node has the focus - Returns:
- the
Stringrepresentation of the node's value
getRowCount
@BeanProperty(bound=false) public int getRowCount()
isRootVisible() is true. This returns 0 if the UI has not been set.- Returns:
- the number of viewable nodes
setSelectionPath
public void setSelectionPath(TreePath path)
getExpandsSelectedPaths is true it is exposed (made viewable).- Parameters:
-
path- theTreePathspecifying the node to select
setSelectionPaths
public void setSelectionPaths(TreePath[] paths)
getExpandsSelectedPaths is true it is exposed (made viewable).- Parameters:
-
paths- an array ofTreePathobjects that specifies the nodes to select
setLeadSelectionPath
@BeanProperty(description="Lead selection path") public void setLeadSelectionPath(TreePath newPath)
JTree, rather the UI will update it. This is a bound property.
- Parameters:
-
newPath- the new lead path - Since:
- 1.3
setAnchorSelectionPath
@BeanProperty(description="Anchor selection path") public void setAnchorSelectionPath(TreePath newPath)
JTree, rather the UI will update it. This is a bound property.
- Parameters:
-
newPath- the new anchor path - Since:
- 1.3
setSelectionRow
public void setSelectionRow(int row)
- Parameters:
-
row- the row to select, where 0 is the first row in the display
setSelectionRows
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.- Parameters:
-
rows- an array of ints specifying the rows to select, where 0 indicates the first row in the display
addSelectionPath
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.
- Parameters:
-
path- theTreePathto add
addSelectionPaths
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.
- Parameters:
-
paths- an array ofTreePathobjects that specifies the nodes to add
addSelectionRow
public void addSelectionRow(int row)
- Parameters:
-
row- an integer specifying the row of the node to add, where 0 is the first row in the display
addSelectionRows
public void addSelectionRows(int[] rows)
- Parameters:
-
rows- an array of ints specifying the rows to add, where 0 indicates the first row in the display
getLastSelectedPathComponent
@BeanProperty(bound=false) public Object getLastSelectedPathComponent()
getSelectionModel().getSelectionPath().getLastPathComponent(). This is typically only useful if the selection has one path.- Returns:
- the last path component of the selected path, or
nullif nothing is selected - See Also:
getLeadSelectionPath
public TreePath getLeadSelectionPath()
- Returns:
- path identified as the lead
getAnchorSelectionPath
public TreePath getAnchorSelectionPath()
- Returns:
- path identified as the anchor
- Since:
- 1.3
getSelectionPath
public TreePath getSelectionPath()
- Returns:
- the
TreePathfor the first selected node, ornullif nothing is currently selected
getSelectionPaths
public TreePath[] getSelectionPaths()
- Returns:
- an array of
TreePathobjects indicating the selected nodes, ornullif nothing is currently selected
getSelectionRows
public int[] getSelectionRows()
TreeSelectionModel. If nothing is selected null or an empty array will be returned, based on the TreeSelectionModel implementation.- Returns:
- an array of integers that identifies all currently selected rows where 0 is the first row in the display
getSelectionCount
@BeanProperty(bound=false) public int getSelectionCount()
- Returns:
- the number of nodes selected
getMinSelectionRow
@BeanProperty(bound=false) public int getMinSelectionRow()
-1 is returned.- Returns:
- the smallest selected row
getMaxSelectionRow
@BeanProperty(bound=false) public int getMaxSelectionRow()
-1 is returned.- Returns:
- the largest selected row
getLeadSelectionRow
@BeanProperty(bound=false) public int getLeadSelectionRow()
- Returns:
- an integer giving the row index of the lead path, where 0 is the first row in the display; or -1 if
leadPathisnull
isPathSelected
public boolean isPathSelected(TreePath path)
- Parameters:
-
path- aTreePathidentifying a node - Returns:
- true if the node is selected
isRowSelected
public boolean isRowSelected(int row)
- Parameters:
-
row- an integer specifying a display row, where 0 is the first row in the display - Returns:
- true if the node is selected
getExpandedDescendants
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.- Parameters:
-
parent- the path which is to be examined - Returns:
- an
Enumerationof the descendents ofparent, ornullifparentis not currently expanded
hasBeenExpanded
public boolean hasBeenExpanded(TreePath path)
- Parameters:
-
path- aTreePathidentifying a node - Returns:
- true if the
pathhas ever been expanded
isExpanded
public boolean isExpanded(TreePath path)
- Parameters:
-
path- theTreePathspecifying the node to check - Returns:
- false if any of the nodes in the node's path are collapsed, true if all nodes in the path are expanded
isExpanded
public boolean isExpanded(int row)
- Parameters:
-
row- the row to check, where 0 is the first row in the display - Returns:
- true if the node is currently expanded, otherwise false
isCollapsed
public boolean isCollapsed(TreePath path)
- Parameters:
-
path- theTreePathto check - Returns:
- true if any of the nodes in the node's path are collapsed, false if all nodes in the path are expanded
isCollapsed
public boolean isCollapsed(int row)
- Parameters:
-
row- the row to check, where 0 is the first row in the display - Returns:
- true if the node is currently collapsed, otherwise false
makeVisible
public void makeVisible(TreePath path)
- Parameters:
-
path- theTreePathto make visible
isVisible
public boolean isVisible(TreePath path)
- Parameters:
-
path-TreePathidentifying a node - Returns:
- true if the node is viewable, otherwise false
getPathBounds
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.
- Parameters:
-
path- theTreePathidentifying the node - Returns:
- the
Rectanglethe node is drawn in, ornull
getRowBounds
public Rectangle getRowBounds(int row)
Rectangle that the node at the specified row is drawn in.- Parameters:
-
row- the row to be drawn, where 0 is the first row in the display - Returns:
- the
Rectanglethe node is drawn in
scrollPathToVisible
public void scrollPathToVisible(TreePath path)
JTree is contained in a JScrollPane.- Parameters:
-
path- theTreePathidentifying the node to bring into view
scrollRowToVisible
public void scrollRowToVisible(int row)
JTree is contained in a JScrollPane.- Parameters:
-
row- an integer specifying the row to scroll, where 0 is the first row in the display
getPathForRow
@BeanProperty(bound=false) public TreePath getPathForRow(int row)
row is not visible, or a TreeUI has not been set, null is returned.- Parameters:
-
row- an integer specifying a row - Returns:
- the
TreePathto the specified node,nullifrow < 0orrow >= getRowCount()
getRowForPath
public int getRowForPath(TreePath path)
- Parameters:
-
path- theTreePathidentifying a node - Returns:
- an integer specifying the display row, where 0 is the first row in the display, or -1 if any of the elements in path are hidden under a collapsed parent.
expandPath
public void expandPath(TreePath path)
- Parameters:
-
path- theTreePathidentifying a node
expandRow
public void expandRow(int row)
If row is < 0 or >= getRowCount this will have no effect.
- Parameters:
-
row- an integer specifying a display row, where 0 is the first row in the display
collapsePath
public void collapsePath(TreePath path)
- Parameters:
-
path- theTreePathidentifying a node
collapseRow
public void collapseRow(int row)
If row is < 0 or >= getRowCount this will have no effect.
- Parameters:
-
row- an integer specifying a display row, where 0 is the first row in the display
getPathForLocation
public TreePath getPathForLocation(int x, int y)
- Parameters:
-
x- an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin -
y- an integer giving the number of pixels vertically from the top of the display area, minus any top margin - Returns:
- the
TreePathfor the node at that location
getRowForLocation
public int getRowForLocation(int x, int y)
- Parameters:
-
x- an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin -
y- an integer giving the number of pixels vertically from the top of the display area, minus any top margin - Returns:
- the row corresponding to the location, or -1 if the location is not within the bounds of a displayed cell
- See Also:
getClosestPathForLocation
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.- Parameters:
-
x- an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin -
y- an integer giving the number of pixels vertically from the top of the display area, minus any top margin - Returns:
- the
TreePathfor the node closest to that location,nullif nothing is viewable or there is no model - See Also:
getClosestRowForLocation
public int getClosestRowForLocation(int x, int y)
- Parameters:
-
x- an integer giving the number of pixels horizontally from the left edge of the display area, minus any left margin -
y- an integer giving the number of pixels vertically from the top of the display area, minus any top margin - Returns:
- the row closest to the location, -1 if nothing is viewable or there is no model
- See Also:
isEditing
@BeanProperty(bound=false) public boolean isEditing()
getSelectionPath.- Returns:
- true if the user is currently editing a node
- See Also:
stopEditing
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).
- Returns:
- true if editing was in progress and is now stopped, false if editing was not in progress
cancelEditing
public void cancelEditing()
startEditingAtPath
public void startEditingAtPath(TreePath path)
CellEditor does not allow editing for the specified item.- Parameters:
-
path- theTreePathidentifying a node
getEditingPath
@BeanProperty(bound=false) public TreePath getEditingPath()
- Returns:
- the
TreePathfor the node being edited
setSelectionModel
@BeanProperty(description="The tree\'s selection model.") public void setSelectionModel(TreeSelectionModel selectionModel)
null value is specified an empty selectionModel is used, which does not allow selections. This is a bound property.
- Parameters:
-
selectionModel- theTreeSelectionModelto use, ornullto disable selections - See Also:
getSelectionModel
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.- Returns:
- the model for selections
- See Also:
getPathBetweenRows
protected TreePath[] getPathBetweenRows(int index0, int index1)
10, and this method is invoked with -1, 20, then the specified indices are constrained to the viewable set of rows, and this is treated as if invoked with 0, 9. On the other hand, if this were invoked with -10, -1, then the specified indices do not bound the viewable set of rows, and an empty array is returned. The parameters are not order dependent. That is,
getPathBetweenRows(x, y) is equivalent to getPathBetweenRows(y, x).
An empty array is returned if the row count is 0, or the specified indices do not bound the viewable set of rows.
- Parameters:
-
index0- the first index in the range -
index1- the last index in the range - Returns:
- the paths (inclusive) between the specified row indices
setSelectionInterval
public void setSelectionInterval(int index0, int index1)
10, and this method is invoked with -1, 20, then the specified indices bounds the viewable range, and this is treated as if invoked with 0, 9. On the other hand, if this were invoked with -10, -1, then the specified indices do not bound the viewable set of rows, and the selection is cleared. The parameters are not order dependent. That is,
setSelectionInterval(x, y) is equivalent to setSelectionInterval(y, x).
- Parameters:
-
index0- the first index in the range to select -
index1- the last index in the range to select
addSelectionInterval
public void addSelectionInterval(int index0, int index1)
10, and this method is invoked with -1, 20, then the specified indices bounds the viewable range, and this is treated as if invoked with 0, 9. On the other hand, if this were invoked with -10, -1, then the specified indices do not bound the viewable set of rows, and the selection is unchanged. The parameters are not order dependent. That is,
addSelectionInterval(x, y) is equivalent to addSelectionInterval(y, x).
- Parameters:
-
index0- the first index in the range to add to the selection -
index1- the last index in the range to add to the selection
removeSelectionInterval
public void removeSelectionInterval(int index0, int index1)
10, and this method is invoked with -1, 20, then the specified range bounds the viewable range, and this is treated as if invoked with 0, 9. On the other hand, if this were invoked with -10, -1, then the specified range does not bound the viewable set of rows, and the selection is unchanged. The parameters are not order dependent. That is,
removeSelectionInterval(x, y) is equivalent to removeSelectionInterval(y, x).
- Parameters:
-
index0- the first row to remove from the selection -
index1- the last row to remove from the selection
removeSelectionPath
public void removeSelectionPath(TreePath path)
- Parameters:
-
path- theTreePathidentifying a node
removeSelectionPaths
public void removeSelectionPaths(TreePath[] paths)
- Parameters:
-
paths- an array ofTreePathobjects that specifies the nodes to remove
removeSelectionRow
public void removeSelectionRow(int row)
row from the current selection.- Parameters:
-
row- the row to remove
removeSelectionRows
public void removeSelectionRows(int[] rows)
- Parameters:
-
rows- an array of ints specifying display rows, where 0 is the first row in the display
clearSelection
public void clearSelection()
isSelectionEmpty
@BeanProperty(bound=false) public boolean isSelectionEmpty()
- Returns:
- true if the selection is currently empty
addTreeExpansionListener
public void addTreeExpansionListener(TreeExpansionListener tel)
TreeExpansion events.- Parameters:
-
tel- a TreeExpansionListener that will be notified when a tree node is expanded or collapsed (a "negative expansion")
removeTreeExpansionListener
public void removeTreeExpansionListener(TreeExpansionListener tel)
TreeExpansion events.- Parameters:
-
tel- theTreeExpansionListenerto remove
getTreeExpansionListeners
@BeanProperty(bound=false) public TreeExpansionListener[] getTreeExpansionListeners()
TreeExpansionListeners added to this JTree with addTreeExpansionListener().- Returns:
- all of the
TreeExpansionListeners added or an empty array if no listeners have been added - Since:
- 1.4
addTreeWillExpandListener
public void addTreeWillExpandListener(TreeWillExpandListener tel)
TreeWillExpand events.- Parameters:
-
tel- aTreeWillExpandListenerthat will be notified when a tree node will be expanded or collapsed (a "negative expansion")
removeTreeWillExpandListener
public void removeTreeWillExpandListener(TreeWillExpandListener tel)
TreeWillExpand events.- Parameters:
-
tel- theTreeWillExpandListenerto remove
getTreeWillExpandListeners
@BeanProperty(bound=false) public TreeWillExpandListener[] getTreeWillExpandListeners()
TreeWillExpandListeners added to this JTree with addTreeWillExpandListener().- Returns:
- all of the
TreeWillExpandListeners added or an empty array if no listeners have been added - Since:
- 1.4
fireTreeExpanded
public void fireTreeExpanded(TreePath path)
path parameter.- Parameters:
-
path- theTreePathindicating the node that was expanded - See Also:
fireTreeCollapsed
public void fireTreeCollapsed(TreePath path)
path parameter.- Parameters:
-
path- theTreePathindicating the node that was collapsed - See Also:
fireTreeWillExpand
public void fireTreeWillExpand(TreePath path) throws ExpandVetoException
path parameter.- Parameters:
-
path- theTreePathindicating the node that was expanded - Throws:
-
ExpandVetoException- if the expansion is prevented from occurring - See Also:
fireTreeWillCollapse
public void fireTreeWillCollapse(TreePath path) throws ExpandVetoException
path parameter.- Parameters:
-
path- theTreePathindicating the node that was expanded - Throws:
-
ExpandVetoException- if the collapse is prevented from occurring - See Also:
addTreeSelectionListener
public void addTreeSelectionListener(TreeSelectionListener tsl)
TreeSelection events.- Parameters:
-
tsl- theTreeSelectionListenerthat will be notified when a node is selected or deselected (a "negative selection")
removeTreeSelectionListener
public void removeTreeSelectionListener(TreeSelectionListener tsl)
TreeSelection listener.- Parameters:
-
tsl- theTreeSelectionListenerto remove
getTreeSelectionListeners
@BeanProperty(bound=false) public TreeSelectionListener[] getTreeSelectionListeners()
TreeSelectionListeners added to this JTree with addTreeSelectionListener().- Returns:
- all of the
TreeSelectionListeners added or an empty array if no listeners have been added - Since:
- 1.4
fireValueChanged
protected void fireValueChanged(TreeSelectionEvent e)
- Parameters:
-
e- theTreeSelectionEventto be fired; generated by theTreeSelectionModelwhen a node is selected or deselected - See Also:
treeDidChange
public void treeDidChange()
setVisibleRowCount
@BeanProperty(description="The number of rows that are to be displayed.") public void setVisibleRowCount(int newCount)
JScrollPane, and will adjust the preferred size and size of that scrollpane. This is a bound property.
- Parameters:
-
newCount- the number of rows to display
getVisibleRowCount
public int getVisibleRowCount()
- Returns:
- the number of rows displayed
getNextMatch
public TreePath getNextMatch(String prefix, int startingRow, Position.Bias bias)
TreePath into a String, convertValueToText is used.- Parameters:
-
prefix- the string to test for a match -
startingRow- the row for starting the search -
bias- the search direction, either Position.Bias.Forward or Position.Bias.Backward. - Returns:
- the TreePath of the next tree element that starts with the prefix; otherwise null
- Throws:
-
IllegalArgumentException- if prefix is null or startingRow is out of bounds - Since:
- 1.4
getPreferredScrollableViewportSize
@BeanProperty(bound=false) public Dimension getPreferredScrollableViewportSize()
JTree. The height is determined from getVisibleRowCount and the width is the current preferred width.- Specified by:
-
getPreferredScrollableViewportSizein interfaceScrollable - Returns:
- a
Dimensionobject containing the preferred size - See Also:
getScrollableUnitIncrement
public int getScrollableUnitIncrement(Rectangle visibleRect, int orientation, int direction)
- Specified by:
-
getScrollableUnitIncrementin interfaceScrollable - Parameters:
-
visibleRect- the view area visible within the viewport -
orientation- eitherSwingConstants.VERTICALorSwingConstants.HORIZONTAL -
direction- less than zero to scroll up/left, greater than zero for down/right - Returns:
- the "unit" increment for scrolling in the specified direction
- See Also:
getScrollableBlockIncrement
public int getScrollableBlockIncrement(Rectangle visibleRect, int orientation, int direction)
visibleRect, based on orientation.- Specified by:
-
getScrollableBlockIncrementin interfaceScrollable - Parameters:
-
visibleRect- the view area visible within the viewport -
orientation- eitherSwingConstants.VERTICALorSwingConstants.HORIZONTAL -
direction- less than zero to scroll up/left, greater than zero for down/right. - Returns:
- the "block" increment for scrolling in the specified direction
- See Also:
getScrollableTracksViewportWidth
@BeanProperty(bound=false) public boolean getScrollableTracksViewportWidth()
- Specified by:
-
getScrollableTracksViewportWidthin interfaceScrollable - Returns:
- whether the tree should track the width of the viewport
- See Also:
getScrollableTracksViewportHeight
@BeanProperty(bound=false) public boolean getScrollableTracksViewportHeight()
- Specified by:
-
getScrollableTracksViewportHeightin interfaceScrollable - Returns:
- whether the tree should track the height of the viewport
- See Also:
setExpandedState
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.
- Parameters:
-
path- aTreePathidentifying a node -
state- iftrue, all parents of @{code path} and path are marked as expanded. Otherwise, all parents ofpathare marked EXPANDED, butpathitself is marked collapsed.
getDescendantToggledPaths
protected Enumeration<TreePath> getDescendantToggledPaths(TreePath parent)
Enumeration of TreePaths that have been expanded that are descendants of parent.- Parameters:
-
parent- a path - Returns:
- the
EnumerationofTreePaths
removeDescendantToggledPaths
protected void removeDescendantToggledPaths(Enumeration<TreePath> toRemove)
TreePaths in toRemove that have been expanded.- Parameters:
-
toRemove- an enumeration of the paths to remove; a value ofnullis ignored - Throws:
-
ClassCastException- iftoRemovecontains an element that is not aTreePath;nullvalues are ignored
clearToggledPaths
protected void clearToggledPaths()
TreeExpansionListener events.createTreeModelListener
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.
- Returns:
- the instance of
TreeModelHandler
removeDescendantSelectedPaths
protected boolean removeDescendantSelectedPaths(TreePath path, boolean includePath)
path. If includePath is true and path is selected, it will be removed from the selection.- Parameters:
-
path- a path -
includePath- istrueandpathis selected, it will be removed from the selection. - Returns:
- true if a descendant was selected
- Since:
- 1.3
paramString
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.- Overrides:
-
paramStringin classJComponent - Returns:
- a string representation of this
JTree.
getAccessibleContext
@BeanProperty(bound=false) public AccessibleContext getAccessibleContext()
- Specified by:
-
getAccessibleContextin interfaceAccessible - Overrides:
-
getAccessibleContextin classComponent - Returns:
- an AccessibleJTree that serves as the AccessibleContext of this JTree
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.desktop/javax/swing/JTree.html