TreeModel (Java SE 19 & JDK 19) (original) (raw)

All Known Implementing Classes:

[DefaultTreeModel](DefaultTreeModel.html "class in javax.swing.tree")


public interface TreeModel

The model used by JTree.

JTree and its related classes make extensive use ofTreePaths for identifying nodes in the TreeModel. If a TreeModel returns the same object, as compared byequals, at two different indices under the same parent then the resulting TreePath objects will be considered equal as well. Some implementations may assume that if twoTreePaths are equal, they identify the same node. If this condition is not met, painting problems and other oddities may result. In other words, if getChild for a given parent returns the same Object (as determined by equals) problems may result, and it is recommended you avoid doing this.

Similarly JTree and its related classes placeTreePaths in Maps. As such if a node is requested twice, the return values must be equal (using the equals method) and have the samehashCode.

For further information on tree models, including an example of a custom implementation, see How to Use Trees in The Java Tutorial.

See Also:

void
Adds a listener for the TreeModelEvent posted after the tree changes.
[getChild](#getChild%28java.lang.Object,int%29)([Object](../../../../java.base/java/lang/Object.html "class in java.lang") parent, int index)
Returns the child of parent at index index in the parent's child array.
int
Returns the number of children of parent.
int
Returns the index of child in parent.
[getRoot](#getRoot%28%29)()
Returns the root of the tree.
boolean
Returns true if node is a leaf.
void
Removes a listener previously added withaddTreeModelListener.
void
Messaged when the user has altered the value for the item identified by path to newValue.