Class BasicTreeUI
- Direct Known Subclasses:
-
MetalTreeUI
,SynthTreeUI
public class BasicTreeUI extends TreeUI
Nested Class Summary
Modifier and Type | Class | Description |
---|---|---|
class |
BasicTreeUI.CellEditorHandler |
Listener responsible for getting cell editing events and updating the tree accordingly. |
class |
BasicTreeUI.ComponentHandler |
Updates the preferred size when scrolling (if necessary). |
class |
BasicTreeUI.FocusHandler |
Repaints the lead selection row when focus is lost/gained. |
class |
BasicTreeUI.KeyHandler |
This is used to get multiple key down events to appropriately generate events. |
class |
BasicTreeUI.MouseHandler |
TreeMouseListener is responsible for updating the selection based on mouse events. |
class |
BasicTreeUI.MouseInputHandler |
MouseInputHandler handles passing all mouse events, including mouse motion events, until the mouse is released to the destination it is constructed with. |
class |
BasicTreeUI.NodeDimensionsHandler |
Class responsible for getting size of node, method is forwarded to BasicTreeUI method. |
class |
BasicTreeUI.PropertyChangeHandler |
PropertyChangeListener for the tree. |
class |
BasicTreeUI.SelectionModelPropertyChangeHandler |
Listener on the TreeSelectionModel, resets the row selection if any of the properties of the model change. |
class |
BasicTreeUI.TreeCancelEditingAction |
ActionListener that invokes cancelEditing when action performed. |
class |
BasicTreeUI.TreeExpansionHandler |
Updates the TreeState in response to nodes expanding/collapsing. |
class |
BasicTreeUI.TreeHomeAction |
TreeHomeAction is used to handle end/home actions. |
class |
BasicTreeUI.TreeIncrementAction |
TreeIncrementAction is used to handle up/down actions. |
class |
BasicTreeUI.TreeModelHandler |
Forwards all TreeModel events to the TreeState. |
class |
BasicTreeUI.TreePageAction |
TreePageAction handles page up and page down events. |
class |
BasicTreeUI.TreeSelectionHandler |
Listens for changes in the selection model and updates the display accordingly. |
class |
BasicTreeUI.TreeToggleAction |
For the first selected row expandedness will be toggled. |
class |
BasicTreeUI.TreeTraverseAction |
TreeTraverseAction is the action used for left/right keys. |
Field Summary
Modifier and Type | Field | Description |
---|---|---|
protected TreeCellEditor |
cellEditor |
Editor for the tree. |
protected Icon |
collapsedIcon |
The collapsed icon. |
protected boolean |
createdCellEditor |
Set to true if editor that is currently in the tree was created by this instance. |
protected boolean |
createdRenderer |
Set to true if the renderer that is currently in the tree was created by this instance. |
protected TreeCellRenderer |
currentCellRenderer |
Renderer that is being used to do the actual cell drawing. |
protected int |
depthOffset |
How much the depth should be offset to properly calculate x locations. |
protected Hashtable<TreePath, |
drawingCache |
Used for minimizing the drawing of vertical lines. |
protected Component |
editingComponent |
When editing, this will be the Component that is doing the actual editing. |
protected TreePath |
editingPath |
Path that is being edited. |
protected int |
editingRow |
Row that is being edited. |
protected boolean |
editorHasDifferentSize |
Set to true if the editor has a different size than the renderer. |
protected Icon |
expandedIcon |
The expanded icon. |
protected boolean |
largeModel |
True if doing optimizations for a largeModel. |
protected int |
lastSelectedRow |
Index of the row that was last selected. |
protected int |
leftChildIndent |
Distance between left margin and where vertical dashes will be drawn. |
protected AbstractLayoutCache.NodeDimensions |
nodeDimensions |
Reponsible for telling the TreeState the size needed for a node. |
protected Dimension |
preferredMinSize |
Minimum preferred size. |
protected Dimension |
preferredSize |
Size needed to completely display all the nodes. |
protected CellRendererPane |
rendererPane |
Used to paint the TreeCellRenderer. |
protected int |
rightChildIndent |
Distance to add to leftChildIndent to determine where cell contents will be drawn. |
protected boolean |
stopEditingInCompleteEditing |
Set to false when editing and shouldSelectCell() returns true meaning the node should be selected before editing, used in completeEditing. |
protected int |
totalChildIndent |
Total distance that will be indented. |
protected JTree |
tree |
Component that we're going to be drawing into. |
protected TreeModel |
treeModel |
Used to determine what to display. |
protected TreeSelectionModel |
treeSelectionModel |
Model maintaining the selection. |
protected AbstractLayoutCache |
treeState |
Object responsible for handling sizing and expanded issues. |
protected boolean |
validCachedPreferredSize |
Is the preferredSize valid? |
Constructor Summary
Constructor | Description |
---|---|
BasicTreeUI() |
Constructs a new instance of BasicTreeUI . |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
void |
cancelEditing |
Cancels the current editing session. |
protected void |
checkForClickInExpandControl |
If the mouseX and mouseY are in the expand/collapse region of the row , this will toggle the row. |
protected void |
completeEditing() |
Messages to stop the editing session. |
protected void |
completeEditing |
Stops the editing session. |
protected void |
completeUIInstall() |
Invoked from installUI after all the defaults/listeners have been installed. |
protected void |
completeUIUninstall() |
Uninstalls UI. |
protected void |
configureLayoutCache() |
Resets the TreeState instance based on the tree we're providing the look and feel for. |
protected CellEditorListener |
createCellEditorListener() |
Creates a listener to handle events from the current editor. |
protected CellRendererPane |
createCellRendererPane() |
Returns the renderer pane that renderer components are placed in. |
protected ComponentListener |
createComponentListener() |
Creates and returns a new ComponentHandler. |
protected TreeCellEditor |
createDefaultCellEditor() |
Creates a default cell editor. |
protected TreeCellRenderer |
createDefaultCellRenderer() |
Returns the default cell renderer that is used to do the stamping of each node. |
protected FocusListener |
createFocusListener() |
Creates a listener that is responsible for updating the display when focus is lost/gained. |
protected KeyListener |
createKeyListener() |
Creates the listener responsible for getting key events from the tree. |
protected AbstractLayoutCache |
createLayoutCache() |
Creates the object responsible for managing what is expanded, as well as the size of nodes. |
protected MouseListener |
createMouseListener() |
Creates the listener responsible for updating the selection based on mouse events. |
protected AbstractLayoutCache.NodeDimensions |
createNodeDimensions() |
Creates an instance of NodeDimensions that is able to determine the size of a given node in the tree. |
protected PropertyChangeListener |
createPropertyChangeListener() |
Creates a listener that is responsible that updates the UI based on how the tree changes. |
protected PropertyChangeListener |
createSelectionModelPropertyChangeListener() |
Creates the listener responsible for getting property change events from the selection model. |
protected TreeExpansionListener |
createTreeExpansionListener() |
Creates and returns the object responsible for updating the treestate when nodes expanded state changes. |
protected TreeModelListener |
createTreeModelListener() |
Returns a listener that can update the tree when the model changes. |
protected TreeSelectionListener |
createTreeSelectionListener() |
Creates the listener that updates the display based on selection change methods. |
static ComponentUI |
createUI |
Constructs a new instance of BasicTreeUI . |
protected void |
drawCentered |
Draws the icon centered at (x,y). |
protected void |
drawDashedHorizontalLine |
Draws a horizontal dashed line. |
protected void |
drawDashedVerticalLine |
Draws a vertical dashed line. |
protected void |
ensureRowsAreVisible |
Ensures that the rows identified by beginRow through endRow are visible. |
int |
getBaseline |
Returns the baseline. |
Component.BaselineResizeBehavior |
getBaselineResizeBehavior |
Returns an enum indicating how the baseline of the component changes as the size changes. |
protected TreeCellEditor |
getCellEditor() |
Returns the editor used to edit entries in the drawn tree component, or null if the tree cannot be edited. |
protected TreeCellRenderer |
getCellRenderer() |
Returns the current instance of the TreeCellRenderer that is rendering each cell. |
TreePath |
getClosestPathForLocation |
Returns the path to the node that is closest to x,y. |
Icon |
getCollapsedIcon() |
Returns the collapsed icon. |
protected Rectangle |
getDropLineRect |
Returns a unbounding box for the drop line. |
TreePath |
getEditingPath |
Returns the path to the element that is being edited. |
Icon |
getExpandedIcon() |
Returns the expanded icon. |
protected Color |
getHashColor() |
Returns the hash color. |
protected int |
getHorizontalLegBuffer() |
The horizontal element of legs between nodes starts at the right of the left-hand side of the child node by default. |
protected TreePath |
getLastChildPath |
Returns a path to the last child of parent . |
protected int |
getLeadSelectionRow() |
Returns the lead row of the selection. |
int |
getLeftChildIndent() |
Returns the left child indent. |
Dimension |
getMaximumSize |
Returns the maximum size for this component, which will be the preferred size if the instance is currently in a JTree, or 0, 0. |
Dimension |
getMinimumSize |
Returns the minimum size for this component. |
protected TreeModel |
getModel() |
Returns the tree model. |
Rectangle |
getPathBounds |
Returns the Rectangle enclosing the label portion that the last item in path will be drawn into. |
TreePath |
getPathForRow |
Returns the path for passed in row. |
Dimension |
getPreferredMinSize() |
Returns the minimum preferred size. |
Dimension |
getPreferredSize |
Returns the preferred size to properly display the tree, this is a cover method for getPreferredSize(c, true) . |
Dimension |
getPreferredSize |
Returns the preferred size to represent the tree in c. |
int |
getRightChildIndent() |
Returns the right child indent. |
int |
getRowCount |
Returns the number of rows that are being displayed. |
int |
getRowForPath |
Returns the row that the last item identified in path is visible at. |
protected int |
getRowHeight() |
Returns the height of each row in the drawn tree component. |
protected int |
getRowX |
Returns the location, along the x-axis, to render a particular row at. |
protected TreeSelectionModel |
getSelectionModel() |
Returns the current instance of the TreeSelectionModel which is the model for selections. |
protected boolean |
getShowsRootHandles() |
Returns true if the root handles are to be displayed. |
protected int |
getVerticalLegBuffer() |
The vertical element of legs between nodes starts at the bottom of the parent node by default. |
protected void |
handleExpandControlClick |
Messaged when the user clicks the particular row, this invokes toggleExpandState . |
protected void |
installComponents() |
Intalls the subcomponents of the tree, which is the renderer pane. |
protected void |
installDefaults() |
Installs default properties. |
protected void |
installKeyboardActions() |
Registers keyboard actions. |
protected void |
installListeners() |
Registers listeners. |
protected boolean |
isDropLine |
Tells if a DropLocation should be indicated by a line between nodes. |
protected boolean |
isEditable() |
Returns whether the drawn tree component should be enabled for editing. |
boolean |
isEditing |
Returns true if the tree is being edited. |
protected boolean |
isLargeModel() |
Returns true if large model is set. |
protected boolean |
isLeaf |
Returns true if the node at row is a leaf. |
protected boolean |
isLocationInExpandControl |
Returns true if mouseX and mouseY fall in the area of row that is used to expand/collapse the node and the node at row does not represent a leaf. |
protected boolean |
isMultiSelectEvent |
Returning true signifies a mouse event on the node should select from the anchor point. |
protected boolean |
isRootVisible() |
Returns whether the root node of the drawn tree component should be displayed. |
protected boolean |
isToggleEvent |
Returning true indicates the row under the mouse should be toggled based on the event. |
protected boolean |
isToggleSelectionEvent |
Returning true signifies a mouse event on the node should toggle the selection of only the row under mouse. |
protected void |
paintDropLine |
Paints the drop line. |
protected void |
paintExpandControl |
Paints the expand (toggle) part of a row. |
protected void |
paintHorizontalLine |
Paints a horizontal line. |
protected void |
paintHorizontalPartOfLeg |
Paints the horizontal part of the leg. |
protected void |
paintRow |
Paints the renderer part of a row. |
protected void |
paintVerticalLine |
Paints a vertical line. |
protected void |
paintVerticalPartOfLeg |
Paints the vertical part of the leg. |
protected void |
pathWasCollapsed |
Messaged from the VisibleTreeNode after it has collapsed. |
protected void |
pathWasExpanded |
Messaged from the VisibleTreeNode after it has been expanded. |
protected void |
prepareForUIInstall() |
Invoked after the tree instance variable has been set, but before any defaults/listeners have been installed. |
protected void |
prepareForUIUninstall() |
Invoked before unstallation of UI. |
protected void |
selectPathForEvent |
Messaged to update the selection based on a MouseEvent over a particular row. |
protected void |
setCellEditor |
Sets the cell editor. |
protected void |
setCellRenderer |
Sets the TreeCellRenderer to tcr . |
void |
setCollapsedIcon |
Sets the collapsed icon. |
protected void |
setEditable |
Configures the receiver to allow, or not allow, editing. |
void |
setExpandedIcon |
Sets the expanded icon. |
protected void |
setHashColor |
Sets the hash color. |
protected void |
setLargeModel |
Sets the largeModel . |
void |
setLeftChildIndent |
Sets the left child indent. |
protected void |
setModel |
Sets the TreeModel . |
void |
setPreferredMinSize |
Sets the preferred minimum size. |
void |
setRightChildIndent |
Sets the right child indent. |
protected void |
setRootVisible |
Sets the root to being visible. |
protected void |
setRowHeight |
Sets the row height, this is forwarded to the treeState. |
protected void |
setSelectionModel |
Resets the selection model. |
protected void |
setShowsRootHandles |
Determines whether the node handles are to be displayed. |
protected boolean |
shouldPaintExpandControl |
Returns true if the expand (toggle) control should be drawn for the specified row. |
protected boolean |
startEditing |
Will start editing for node if there is a cellEditor and shouldSelectCell returns true . |
void |
startEditingAtPath |
Selects the last item in path and tries to edit it. |
boolean |
stopEditing |
Stops the current editing session. |
protected void |
toggleExpandState |
Expands path if it is not expanded, or collapses row if it is expanded. |
protected void |
uninstallComponents() |
Uninstalls the renderer pane. |
protected void |
uninstallDefaults() |
Uninstalls default properties. |
protected void |
uninstallKeyboardActions() |
Unregisters keyboard actions. |
protected void |
uninstallListeners() |
Unregisters listeners. |
protected void |
updateCachedPreferredSize() |
Updates the preferredSize instance variable, which is returned from getPreferredSize() . |
protected void |
updateCellEditor() |
Updates the cellEditor based on the editability of the JTree that we're contained in. |
protected void |
updateDepthOffset() |
Updates how much each depth should be offset by. |
protected void |
updateExpandedDescendants |
Updates the expanded state of all the descendants of path by getting the expanded descendants from the tree and forwarding to the tree state. |
protected void |
updateLayoutCacheExpandedNodes() |
Makes all the nodes that are expanded in JTree expanded in LayoutCache. |
protected void |
updateLeadSelectionRow() |
Updates the lead row of the selection. |
protected void |
updateRenderer() |
Messaged from the tree we're in when the renderer has changed. |
protected void |
updateSize() |
Marks the cached size as being invalid, and messages the tree with treeDidChange . |
Methods declared in class javax.swing.plaf.ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, installUI, paint, uninstallUI, update
Field Details
collapsedIcon
protected transient Icon collapsedIcon
expandedIcon
protected transient Icon expandedIcon
leftChildIndent
protected int leftChildIndent
rightChildIndent
protected int rightChildIndent
totalChildIndent
protected int totalChildIndent
preferredMinSize
protected Dimension preferredMinSize
lastSelectedRow
protected int lastSelectedRow
tree
protected JTree tree
currentCellRenderer
protected transient TreeCellRenderer currentCellRenderer
createdRenderer
protected boolean createdRenderer
cellEditor
protected transient TreeCellEditor cellEditor
createdCellEditor
protected boolean createdCellEditor
stopEditingInCompleteEditing
protected boolean stopEditingInCompleteEditing
rendererPane
protected CellRendererPane rendererPane
preferredSize
protected Dimension preferredSize
validCachedPreferredSize
protected boolean validCachedPreferredSize
treeState
protected AbstractLayoutCache treeState
drawingCache
protected Hashtable<TreePath,Boolean> drawingCache
largeModel
protected boolean largeModel
nodeDimensions
protected AbstractLayoutCache.NodeDimensions nodeDimensions
treeModel
protected TreeModel treeModel
treeSelectionModel
protected TreeSelectionModel treeSelectionModel
depthOffset
protected int depthOffset
editingComponent
protected Component editingComponent
editingPath
protected TreePath editingPath
editingRow
protected int editingRow
editorHasDifferentSize
protected boolean editorHasDifferentSize
Constructor Details
BasicTreeUI
public BasicTreeUI()
BasicTreeUI
.Method Details
createUI
public static ComponentUI createUI(JComponent x)
BasicTreeUI
.- Parameters:
-
x
- a component - Returns:
- a new instance of
BasicTreeUI
getHashColor
protected Color getHashColor()
- Returns:
- the hash color
setHashColor
protected void setHashColor(Color color)
- Parameters:
-
color
- the hash color
setLeftChildIndent
public void setLeftChildIndent(int newAmount)
- Parameters:
-
newAmount
- the left child indent
getLeftChildIndent
public int getLeftChildIndent()
- Returns:
- the left child indent
setRightChildIndent
public void setRightChildIndent(int newAmount)
- Parameters:
-
newAmount
- the right child indent
getRightChildIndent
public int getRightChildIndent()
- Returns:
- the right child indent
setExpandedIcon
public void setExpandedIcon(Icon newG)
- Parameters:
-
newG
- the expanded icon
getExpandedIcon
public Icon getExpandedIcon()
- Returns:
- the expanded icon
setCollapsedIcon
public void setCollapsedIcon(Icon newG)
- Parameters:
-
newG
- the collapsed icon
getCollapsedIcon
public Icon getCollapsedIcon()
- Returns:
- the collapsed icon
setLargeModel
protected void setLargeModel(boolean largeModel)
largeModel
. Called when the largeModel
property is changed in the drawn tree component.- Parameters:
-
largeModel
- the new value of thelargeModel
property
isLargeModel
protected boolean isLargeModel()
true
if large model is set.- Returns:
-
true
if large model is set
setRowHeight
protected void setRowHeight(int rowHeight)
rowHeight
property is changed in the drawn tree component.- Parameters:
-
rowHeight
- the new value of therowHeight
property
getRowHeight
protected int getRowHeight()
- Returns:
- the height of each row, in pixels
setCellRenderer
protected void setCellRenderer(TreeCellRenderer tcr)
TreeCellRenderer
to tcr
. This invokes updateRenderer
. Called when the cellRenderer
property is changed in the drawn tree component.- Parameters:
-
tcr
- the new value of thecellRenderer
property
getCellRenderer
protected TreeCellRenderer getCellRenderer()
TreeCellRenderer
that is rendering each cell.- Returns:
- the
TreeCellRenderer
instance
setModel
protected void setModel(TreeModel model)
TreeModel
.- Parameters:
-
model
- the new value
getModel
protected TreeModel getModel()
- Returns:
- the tree model
setRootVisible
protected void setRootVisible(boolean newValue)
rootVisible
property is changed in the drawn tree component.- Parameters:
-
newValue
- the new value of therootVisible
property
isRootVisible
protected boolean isRootVisible()
- Returns:
-
true
if the root node of the tree is displayed
setShowsRootHandles
protected void setShowsRootHandles(boolean newValue)
showsRootHandles
property is changed in the drawn tree component.- Parameters:
-
newValue
- the new value of theshowsRootHandles
property
getShowsRootHandles
protected boolean getShowsRootHandles()
true
if the root handles are to be displayed.- Returns:
-
true
if the root handles are to be displayed
setCellEditor
protected void setCellEditor(TreeCellEditor editor)
cellEditor
property is changed in the drawn tree component.- Parameters:
-
editor
- the new value of thecellEditor
property
getCellEditor
protected TreeCellEditor getCellEditor()
null
if the tree cannot be edited.- Returns:
- the
TreeCellEditor
instance, ornull
setEditable
protected void setEditable(boolean newValue)
editable
property is changed in the drawn tree component.- Parameters:
-
newValue
- the new value of theeditable
property
isEditable
protected boolean isEditable()
- Returns:
-
true
if the tree is editable
setSelectionModel
protected void setSelectionModel(TreeSelectionModel newLSM)
selectionModel
property is changed in the drawn tree component.- Parameters:
-
newLSM
- the new value of theselectionModel
property
getSelectionModel
protected TreeSelectionModel getSelectionModel()
TreeSelectionModel
which is the model for selections.- Returns:
- the
TreeSelectionModel
instance
getPathBounds
public Rectangle getPathBounds(JTree tree, TreePath path)
- Specified by:
-
getPathBounds
in classTreeUI
- Parameters:
-
tree
- theJTree
forpath
-
path
- theTreePath
identifying the node - Returns:
- the
Rectangle
enclosing the label portion that the last item in path will be drawn into,null
if any component in path is currently valid.
getPathForRow
public TreePath getPathForRow(JTree tree, int row)
- Specified by:
-
getPathForRow
in classTreeUI
- Parameters:
-
tree
- aJTree
object -
row
- an integer specifying a row - Returns:
- the
path
forrow
ornull
ifrow
is not visible
getRowForPath
public int getRowForPath(JTree tree, TreePath path)
- Specified by:
-
getRowForPath
in classTreeUI
- Parameters:
-
tree
- theJTree
forpath
-
path
- theTreePath
object to look in - Returns:
- an integer specifying the row at which the last item identified is visible, -1 if any of the elements in
path
are not currently visible
getRowCount
public int getRowCount(JTree tree)
- Specified by:
-
getRowCount
in classTreeUI
- Parameters:
-
tree
- theJTree
for which to count rows - Returns:
- an integer specifying the number of row being displayed
getClosestPathForLocation
public TreePath getClosestPathForLocation(JTree tree, int x, int y)
- Specified by:
-
getClosestPathForLocation
in classTreeUI
- Parameters:
-
tree
- aJTree
object -
x
- an integer giving the number of pixels horizontally from the left edge of the display area -
y
- an integer giving the number of pixels vertically from the top of the display area, minus any top margin - Returns:
- the
TreePath
node closest tox,y
ornull
if there is nothing currently visible
isEditing
public boolean isEditing(JTree tree)
stopEditing
public boolean stopEditing(JTree tree)
- Specified by:
-
stopEditing
in classTreeUI
- Parameters:
-
tree
- aJTree
object - Returns:
- true if the editor allows the editing session to stop
cancelEditing
public void cancelEditing(JTree tree)
- Specified by:
-
cancelEditing
in classTreeUI
- Parameters:
-
tree
- aJTree
object
startEditingAtPath
public void startEditingAtPath(JTree tree, TreePath path)
- Specified by:
-
startEditingAtPath
in classTreeUI
- Parameters:
-
tree
- theJTree
being edited -
path
- theTreePath
to be edited
getEditingPath
public TreePath getEditingPath(JTree tree)
- Specified by:
-
getEditingPath
in classTreeUI
- Parameters:
-
tree
- theJTree
for which to return a path - Returns:
- a
TreePath
containing the path totree
prepareForUIInstall
protected void prepareForUIInstall()
tree
instance variable has been set, but before any defaults/listeners have been installed.completeUIInstall
protected void completeUIInstall()
installDefaults
protected void installDefaults()
installListeners
protected void installListeners()
installKeyboardActions
protected void installKeyboardActions()
installComponents
protected void installComponents()
createNodeDimensions
protected AbstractLayoutCache.NodeDimensions createNodeDimensions()
NodeDimensions
that is able to determine the size of a given node in the tree.- Returns:
- an instance of
NodeDimensions
createPropertyChangeListener
protected PropertyChangeListener createPropertyChangeListener()
- Returns:
- an instance of the
PropertyChangeListener
createMouseListener
protected MouseListener createMouseListener()
- Returns:
- an instance of the
MouseListener
createFocusListener
protected FocusListener createFocusListener()
- Returns:
- an instance of the
FocusListener
createKeyListener
protected KeyListener createKeyListener()
- Returns:
- an instance of the
KeyListener
createSelectionModelPropertyChangeListener
protected PropertyChangeListener createSelectionModelPropertyChangeListener()
- Returns:
- an instance of the
PropertyChangeListener
createTreeSelectionListener
protected TreeSelectionListener createTreeSelectionListener()
- Returns:
- an instance of the
TreeSelectionListener
createCellEditorListener
protected CellEditorListener createCellEditorListener()
- Returns:
- an instance of the
CellEditorListener
createComponentListener
protected ComponentListener createComponentListener()
- Returns:
- an instance of the
ComponentListener
createTreeExpansionListener
protected TreeExpansionListener createTreeExpansionListener()
- Returns:
- an instance of the
TreeExpansionListener
createLayoutCache
protected AbstractLayoutCache createLayoutCache()
- Returns:
- the object responsible for managing what is expanded
createCellRendererPane
protected CellRendererPane createCellRendererPane()
- Returns:
- an instance of the
CellRendererPane
createDefaultCellEditor
protected TreeCellEditor createDefaultCellEditor()
- Returns:
- a default cell editor
createDefaultCellRenderer
protected TreeCellRenderer createDefaultCellRenderer()
- Returns:
- an instance of
TreeCellRenderer
createTreeModelListener
protected TreeModelListener createTreeModelListener()
- Returns:
- an instance of the
TreeModelListener
.
prepareForUIUninstall
protected void prepareForUIUninstall()
completeUIUninstall
protected void completeUIUninstall()
uninstallDefaults
protected void uninstallDefaults()
uninstallListeners
protected void uninstallListeners()
uninstallKeyboardActions
protected void uninstallKeyboardActions()
uninstallComponents
protected void uninstallComponents()
getBaseline
public int getBaseline(JComponent c, int width, int height)
- Overrides:
-
getBaseline
in classComponentUI
- Parameters:
-
c
-JComponent
baseline is being requested for -
width
- the width to get the baseline for -
height
- the height to get the baseline for - Returns:
- baseline or a value < 0 indicating there is no reasonable baseline
- Throws:
-
NullPointerException
- ifc
isnull
-
IllegalArgumentException
- if width or height is < 0 - Since:
- 1.6
- See Also:
getBaselineResizeBehavior
public Component.BaselineResizeBehavior getBaselineResizeBehavior(JComponent c)
- Overrides:
-
getBaselineResizeBehavior
in classComponentUI
- Parameters:
-
c
-JComponent
to return baseline resize behavior for - Returns:
- an enum indicating how the baseline changes as the component size changes
- Throws:
-
NullPointerException
- ifc
isnull
- Since:
- 1.6
- See Also:
isDropLine
protected boolean isDropLine(JTree.DropLocation loc)
DropLocation
should be indicated by a line between nodes. This is meant for javax.swing.DropMode.INSERT
and javax.swing.DropMode.ON_OR_INSERT
drop modes.- Parameters:
-
loc
- aDropLocation
- Returns:
-
true
if the drop location should be shown as a line - Since:
- 1.7
paintDropLine
protected void paintDropLine(Graphics g)
- Parameters:
-
g
-Graphics
object to draw on - Since:
- 1.7
getDropLineRect
protected Rectangle getDropLineRect(JTree.DropLocation loc)
- Parameters:
-
loc
- aDropLocation
- Returns:
- bounding box for the drop line
- Since:
- 1.7
paintHorizontalPartOfLeg
protected void paintHorizontalPartOfLeg(Graphics g, Rectangle clipBounds, Insets insets, Rectangle bounds, TreePath path, int row, boolean isExpanded, boolean hasBeenExpanded, boolean isLeaf)
clipBounds
, or insets
. NOTE: parentRow
can be -1 if the root is not visible.
- Parameters:
-
g
- a graphics context -
clipBounds
- a clipped rectangle -
insets
- insets -
bounds
- a bounding rectangle -
path
- a tree path -
row
- a row -
isExpanded
-true
if the path is expanded -
hasBeenExpanded
-true
if the path has been expanded -
isLeaf
-true
if the path is leaf
paintVerticalPartOfLeg
protected void paintVerticalPartOfLeg(Graphics g, Rectangle clipBounds, Insets insets, TreePath path)
clipBounds
, insets
.- Parameters:
-
g
- a graphics context -
clipBounds
- a clipped rectangle -
insets
- insets -
path
- a tree path
paintExpandControl
protected void paintExpandControl(Graphics g, Rectangle clipBounds, Insets insets, Rectangle bounds, TreePath path, int row, boolean isExpanded, boolean hasBeenExpanded, boolean isLeaf)
clipBounds
, or insets
.- Parameters:
-
g
- a graphics context -
clipBounds
- a clipped rectangle -
insets
- insets -
bounds
- a bounding rectangle -
path
- a tree path -
row
- a row -
isExpanded
-true
if the path is expanded -
hasBeenExpanded
-true
if the path has been expanded -
isLeaf
-true
if the row is leaf
paintRow
protected void paintRow(Graphics g, Rectangle clipBounds, Insets insets, Rectangle bounds, TreePath path, int row, boolean isExpanded, boolean hasBeenExpanded, boolean isLeaf)
clipBounds
, or insets
.- Parameters:
-
g
- a graphics context -
clipBounds
- a clipped rectangle -
insets
- insets -
bounds
- a bounding rectangle -
path
- a tree path -
row
- a row -
isExpanded
-true
if the path is expanded -
hasBeenExpanded
-true
if the path has been expanded -
isLeaf
-true
if the path is leaf
shouldPaintExpandControl
protected boolean shouldPaintExpandControl(TreePath path, int row, boolean isExpanded, boolean hasBeenExpanded, boolean isLeaf)
true
if the expand (toggle) control should be drawn for the specified row.- Parameters:
-
path
- a tree path -
row
- a row -
isExpanded
-true
if the path is expanded -
hasBeenExpanded
-true
if the path has been expanded -
isLeaf
-true
if the row is leaf - Returns:
-
true
if the expand (toggle) control should be drawn for the specified row
paintVerticalLine
protected void paintVerticalLine(Graphics g, JComponent c, int x, int top, int bottom)
- Parameters:
-
g
- a graphics context -
c
- a component -
x
- an X coordinate -
top
- an Y1 coordinate -
bottom
- an Y2 coordinate
paintHorizontalLine
protected void paintHorizontalLine(Graphics g, JComponent c, int y, int left, int right)
- Parameters:
-
g
- a graphics context -
c
- a component -
y
- an Y coordinate -
left
- an X1 coordinate -
right
- an X2 coordinate
getVerticalLegBuffer
protected int getVerticalLegBuffer()
- Returns:
- the vertical leg buffer
getHorizontalLegBuffer
protected int getHorizontalLegBuffer()
- Returns:
- the horizontal leg buffer
drawCentered
protected void drawCentered(Component c, Graphics graphics, Icon icon, int x, int y)
icon
centered at (x,y).- Parameters:
-
c
- a component -
graphics
- a graphics context -
icon
- an icon -
x
- an X coordinate -
y
- an Y coordinate
drawDashedHorizontalLine
protected void drawDashedHorizontalLine(Graphics g, int y, int x1, int x2)
x1
<= x2
. If x1
is greater than x2
, the method draws nothing.- Parameters:
-
g
- an instance ofGraphics
-
y
- an Y coordinate -
x1
- an X1 coordinate -
x2
- an X2 coordinate
drawDashedVerticalLine
protected void drawDashedVerticalLine(Graphics g, int x, int y1, int y2)
y1
<= y2
. If y1
is greater than y2
, the method draws nothing.- Parameters:
-
g
- an instance ofGraphics
-
x
- an X coordinate -
y1
- an Y1 coordinate -
y2
- an Y2 coordinate
getRowX
protected int getRowX(int row, int depth)
- Parameters:
-
row
- Row to return x location for -
depth
- Depth of the row - Returns:
- amount to indent the given row.
- Since:
- 1.5
updateLayoutCacheExpandedNodes
protected void updateLayoutCacheExpandedNodes()
updateExpandedDescendants
protected void updateExpandedDescendants(TreePath path)
path
by getting the expanded descendants from the tree and forwarding to the tree state.- Parameters:
-
path
- a tree path
getLastChildPath
protected TreePath getLastChildPath(TreePath parent)
parent
.- Parameters:
-
parent
- a tree path - Returns:
- a path to the last child of
parent
updateDepthOffset
protected void updateDepthOffset()
updateCellEditor
protected void updateCellEditor()
updateRenderer
protected void updateRenderer()
configureLayoutCache
protected void configureLayoutCache()
updateSize
protected void updateSize()
treeDidChange
.updateCachedPreferredSize
protected void updateCachedPreferredSize()
preferredSize
instance variable, which is returned from getPreferredSize()
.For left to right orientations, the size is determined from the current AbstractLayoutCache. For RTL orientations, the preferred size becomes the width minus the minimum x position.
pathWasExpanded
protected void pathWasExpanded(TreePath path)
VisibleTreeNode
after it has been expanded.- Parameters:
-
path
- a tree path
pathWasCollapsed
protected void pathWasCollapsed(TreePath path)
VisibleTreeNode
after it has collapsed.- Parameters:
-
path
- a tree path
ensureRowsAreVisible
protected void ensureRowsAreVisible(int beginRow, int endRow)
beginRow
through endRow
are visible.- Parameters:
-
beginRow
- the begin row -
endRow
- the end row
setPreferredMinSize
public void setPreferredMinSize(Dimension newSize)
- Parameters:
-
newSize
- the new preferred size
getPreferredMinSize
public Dimension getPreferredMinSize()
- Returns:
- the minimum preferred size
getPreferredSize
public Dimension getPreferredSize(JComponent c)
getPreferredSize(c, true)
.- Overrides:
-
getPreferredSize
in classComponentUI
- Parameters:
-
c
- a component - Returns:
- the preferred size to represent the tree in the component
- See Also:
getPreferredSize
public Dimension getPreferredSize(JComponent c, boolean checkConsistency)
true
checkConsistency is messaged first.- Parameters:
-
c
- a component -
checkConsistency
- iftrue
consistency is checked - Returns:
- the preferred size to represent the tree in the component
getMinimumSize
public Dimension getMinimumSize(JComponent c)
- Overrides:
-
getMinimumSize
in classComponentUI
- Parameters:
-
c
- the component whose minimum size is being queried; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components - Returns:
- a
Dimension
object ornull
- See Also:
getMaximumSize
public Dimension getMaximumSize(JComponent c)
- Overrides:
-
getMaximumSize
in classComponentUI
- Parameters:
-
c
- the component whose maximum size is being queried; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components - Returns:
- a
Dimension
object ornull
- See Also:
completeEditing
protected void completeEditing()
getInvokesStopCellEditing
, stopCellEditing will invoked on the current editor. Then completeEditing will be messaged with false, true, false to cancel any lingering editing.completeEditing
protected void completeEditing(boolean messageStop, boolean messageCancel, boolean messageTree)
messageStop
is true
the editor is messaged with stopEditing
, if messageCancel
is true
the editor is messaged with cancelEditing
. If messageTree
is true
the treeModel
is messaged with valueForPathChanged
.- Parameters:
-
messageStop
- message to stop editing -
messageCancel
- message to cancel editing -
messageTree
- message to tree
startEditing
protected boolean startEditing(TreePath path, MouseEvent event)
cellEditor
and shouldSelectCell
returns true
.This assumes that path is valid and visible.
- Parameters:
-
path
- a tree path -
event
- a mouse event - Returns:
-
true
if the editing is successful
checkForClickInExpandControl
protected void checkForClickInExpandControl(TreePath path, int mouseX, int mouseY)
mouseX
and mouseY
are in the expand/collapse region of the row
, this will toggle the row.- Parameters:
-
path
- a tree path -
mouseX
- an X coordinate -
mouseY
- an Y coordinate
isLocationInExpandControl
protected boolean isLocationInExpandControl(TreePath path, int mouseX, int mouseY)
true
if mouseX
and mouseY
fall in the area of row that is used to expand/collapse the node and the node at row
does not represent a leaf.- Parameters:
-
path
- a tree path -
mouseX
- an X coordinate -
mouseY
- an Y coordinate - Returns:
-
true
if the mouse cursor fall in the area of row that is used to expand/collapse the node and the node is not a leaf.
handleExpandControlClick
protected void handleExpandControlClick(TreePath path, int mouseX, int mouseY)
toggleExpandState
.- Parameters:
-
path
- a tree path -
mouseX
- an X coordinate -
mouseY
- an Y coordinate
toggleExpandState
protected void toggleExpandState(TreePath path)
JTree
scrolls on expand, ensureRowsAreVisible
is invoked to scroll as many of the children to visible as possible (tries to scroll to last visible descendant of path).- Parameters:
-
path
- a tree path
isToggleSelectionEvent
protected boolean isToggleSelectionEvent(MouseEvent event)
true
signifies a mouse event on the node should toggle the selection of only the row under mouse.- Parameters:
-
event
- a mouse event - Returns:
-
true
if a mouse event on the node should toggle the selection
isMultiSelectEvent
protected boolean isMultiSelectEvent(MouseEvent event)
true
signifies a mouse event on the node should select from the anchor point.- Parameters:
-
event
- a mouse event - Returns:
-
true
if a mouse event on the node should select from the anchor point
isToggleEvent
protected boolean isToggleEvent(MouseEvent event)
true
indicates the row under the mouse should be toggled based on the event. This is invoked after checkForClickInExpandControl
, implying the location is not in the expand (toggle) control.- Parameters:
-
event
- a mouse event - Returns:
-
true
if the row under the mouse should be toggled
selectPathForEvent
protected void selectPathForEvent(TreePath path, MouseEvent event)
MouseEvent
over a particular row. If the event is a toggle selection event, the row is either selected, or deselected. If the event identifies a multi selection event, the selection is updated from the anchor point. Otherwise the row is selected, and if the event specified a toggle event the row is expanded/collapsed.- Parameters:
-
path
- the selected path -
event
- the mouse event
isLeaf
protected boolean isLeaf(int row)
true
if the node at row
is a leaf.- Parameters:
-
row
- a row - Returns:
-
true
if the node atrow
is a leaf
updateLeadSelectionRow
protected void updateLeadSelectionRow()
- Since:
- 1.7
getLeadSelectionRow
protected int getLeadSelectionRow()
- Returns:
- selection lead row
- Since:
- 1.7
© 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/plaf/basic/BasicTreeUI.html