Tree Widget API
For the tree control and the nodes in the tree, the model manager provides two controls, Tree
and TreeItem
. The Tree
control represents the entire tree, and the TreeItem
represents each node in the tree. Since the name of the node is not unique, it is unreliable to use the node name as the identification attribute. The model manager provides an identification attribute describing the location of the node-itemPath
.
Corresponding walkthroughs are also provided for the list controls-Walkthrough: Operating Tree in Qt Applications, which can greatly deepen the understanding of the API.
Tree view control: Tree
For the Tree
control, most of the related nodes are operated by passing in the itemPath
; and the TreeItem
control itself originally represents the node, so it is usually not necessary to pass parameters for its operation.
export interface IQTree extends IQtControl {
getItem(itemPath: ItemPath): IQTreeItem;
findItem(text: string): Promise<IQTreeItem | null>;
scrollTo(itemPath: ItemPath): Promise<void>;
scrollToTop(): Promise<void>;
scrollToBottom(): Promise<void>;
collapseAll(itemPath: ItemPath): Promise<void>;
children(): Promise<IQTreeItem[]>;
childCount(): Promise<number>;
rowData(itemPath: ItemPath): Promise<string[]>;
columnCount(): Promise<number>;
columnHeaders(): Promise<string[]>;
}
export type ItemPath = (number | [number, number])[];
class QTree(QtControl):
def columnHeaders() -> List[str]
def collapseAll(itemPath: TypedDict) -> None
def getItem(itemPath: TypedDict) -> "QTreeItem"
def findItem(text: str, options: Optional[FindItemOptional]=None) -> "QTreeItem"
def rowData(itemPath: TypedDict) -> List[str]
def columnData(nameOrIndex: Union[str, int]) -> List[str]
def select(itemPath: TypedDict) -> "QTreeItem"
def childCount() -> int
def children() -> "List[QTreeItem]"
def columnCount() -> int
def scrollToTop() -> None
def scrollTo(itemPath: TypedDict) -> "QTreeItem"
def scrollToBottom() -> None
Object manipulation API
The following is the object manipulation API for the Tree
control.
getItem(itemPath): IQTreeItem
Get the automation object corresponding to the tree node at the specified itemPath
location.
- itemPath:
ItemPath
type, representing the location of the node. - Return value:
IQTreeItem
type, which is the automation object of theListItem
control. Note that this is a synchronous method and does not require theawait
keyword, nor will it match the controls in the application. Matches are only performed when an asynchronous method on the object is executed.
findItem(text: string): Promise<IQTreeItem | null>
Search the target tree node based on the name in the tree, return the automation object of the target tree node, or return null
if it is not found. Since it needs to search the tree in the application in real time, it is an asynchronous method.
- text:
string
type, the content or text of the desired target tree node; - Return value:
Promise<IQTreeItem>
orPromise<null>
type, asynchronously search the target tree node in the application, and returnnull
if it is not found.findItem() search strategy: The
findItem()
method adopts a "breadth first" search strategy, that is, first search for the tree node that satisfies the condition (ie the tree node that meets the name) in the current level; if none Satisfaction will lead to the next level. If it is an unexpanded node, it will usually not be searched, so if you need to get a deeper tree node, the best way is to call thefindItem()
method layer by layer to ensure all The nodes can be searched correctly. For this, the tree node also provides the findItem() method.
select(itemPath): Promise<void>
Select the tree node at the specified location.
- index:
ItemPath
type, the location of the target node. - Return value: Asynchronous method that does not return any value.
scrollToTop(): Promise<void>
Scroll to the top of the tree.
- Return value: Asynchronous method that does not return any value.
scrollTo(itemPath): Promise<void>
Scroll to the location of the target tree node. If the target location has not been expanded, it will be expanded until the target node is made visible.
- itemPath:
ItemPath
type, the location of the target node. - Return value: Asynchronous method that does not return any value.
scrollToBottom(): Promise<void>
Scroll to the top of the tree.
- Return value: Asynchronous method that does not return any value.
collapseAll(itemPath: ItemPath): Promise<void>
Collapse all tree nodes on the specified path.
- itemPath:
ItemPath
type, the location of the target node. - Return value: Asynchronous method that does not return any value.
children(): Promise<IQTreeItem[]>
Asynchronously get all the immediate child nodes of the current tree and return them in the form of an array.
- Return value: an array composed of automation objects of type
TreeItem
. And it is an asynchronous method, which requires the use of theawait
keyword.
childCount(): Promise<number>
Asynchronously get the number of all the immediate child nodes of the current tree, and return the number.
- Return value:
number
type, the number of immediate child nodes, which can be understood as the length of the array returned by thechildren()
method. And it is an asynchronous method, which requires the use of theawait
keyword.
rowData(itemPath: ItemPath): Promise<string[]>
Get all the attributes of the target tree node and return it as an array.
- itemPath:
ItemPath
type, the location of the target node. - Return value:
string[]
type, a string array composed of tree node attributes.For example, for the file tree, the attributes of a file node may contain the values of
[file name, file size, file type, last modified time]
.
columnHeaders(): Promise<string[]>
Get the attribute name of the tree, that is, the column header content of each column in the tree, and return it in the form of a string array.
- Return value:
string[]
type, a string array composed of attribute names.
columnCount(): Promise<number>
Get the number of attributes of the tree, that is, how many columns there are in the tree. It is numerically equal to the length of the array returned by the columnHeaders()
method.
- Return value
number
type, the number of attributes.
Tree node control: TreeItem
For the automation object TreeItem
of each node control in the tree, you can expand or collapse it, get its child nodes, and so on.
Compared to all tree node operations in the previous section, the itemPath
parameter must be passed in to locate the tree node being manipulated.
Type definition file
The type definition file is as follows:
export interface IQTreeItem extends IQtControl {
select(): Promise<void>;
findItem(): Promise<void>;
expand(): Promise<void>;
collapse(): Promise<void>;
scrollIntoView(): Promise<void>;
set(value: string): Promise<void>;
exists(seconds: number): Promise<boolean>;
value(): Promise<string>;
rowData(): Promise<string[]>;
expandable(): Promise<boolean>;
expanded(): Promise<boolean>;
childCount(): Promise<number>;
children(): Promise<IQTreeItem[]>;
rowIndex(): Promise<number>;
columnIndex(): Promise<number>;
itemPath(): Promise<ItemPath>;
}
class QTreeItem(QItemViewItem):
def expand() -> None
def collapse() -> None
def exists(seconds: int) -> bool
def value() -> str
def rowData() -> List[str]
def scrollIntoView() -> None
def set(value: str) -> None
def select() -> None
def expandable() -> bool
def expanded() -> bool
def childCount() -> int
def children() -> "List[QTreeItem]"
def rowIndex() -> int
def columnIndex() -> int
def itemPath() -> TypedDict
def getItem(itemPath: TypedDict) -> "QTreeItem"
def findItem(text: str, options: Optional[FindItemOptional]=None) -> "QTreeItem"
def checkState() -> Union[bool, str]
def toggleCheck(checkState: Union[bool, str]) -> None
Object manipulation API
value(): Promise<string>
Get the name of the tree node.
- Return value:
Promise<string>
type, representing the name of the tree node. You need to use theawait
keyword to retrieve the results.
findItem(text: string): Promise<IQTreeItem | null>
Search for the target tree node based on the name in the current tree node, return the automation object of the target tree node, or return null
if it is not found. Since it needs to search the tree in the application in real time, it is an asynchronous method.
- text:
string
type, expect the content or text of the target tree node; - Return value:
Promise<IQTreeItem>
orPromise<null>
type, asynchronously search the target tree node in the application, and returnnull
if it is not found.Expand the current node before searching to avoid the situation that the child node cannot be found.
scrollIntoView(): Promise<void>
Scroll to the tree node position. If the location of the tree node is collapsed, all tree nodes on the path will be expanded.
- Return value: Asynchronous method that does not return any value.
select(): Promise<void>
Select the tree node. If the node is not in the visible range, it will automatically scroll to the location of the item.
This method will automatically execute the
scrollIntoView()
method to expand and scroll to the target node when the node is not in the visible range.
- Return value: Asynchronous method that does not return any value.
expand(): Promise<void>
Expanding the tree node, if it is a node that cannot be expanded, there will be no effect.
- Return value: Asynchronous method that does not return any value.
collapse(): Promise<void>
Expand the tree node, if it is a node that cannot be collapsed, there will be no effect.
- Return value: Asynchronous method that does not return any value.
set(value: string): Promise<void>
Modify the value of the tree node. If it is a node that cannot be edited, there will be no results.
- Return value: Asynchronous method that does not return any value.
exists(seconds: number): Promise<boolean>
Whether the current tree node is in the expanded tree, the input parameter is the waiting time.
- seconds:
number
type, waiting time, if it is stillfalse
after the waiting time, it will return. - Return value:
boolean
type, whether it exists.
children(): Promise<IQTreeItem[]>
Asynchronously get all the immediate child nodes of the current tree node and return them in the form of an array.
- Return value: an array composed of automation objects of type
TreeItem
. And it is an asynchronous method, which requires the use of theawait
keyword.
childCount(): Promise<number>
Asynchronously get the number of all immediate child nodes of the current tree node, and return the number.
- Return value:
number
type, the number of immediate child nodes, which can be understood as the length of the array returned by thechildren()
method. And it is an asynchronous method, which requires the use of theawait
keyword.
rowData(): Promise<string[]>
Get all the attributes of the tree node and return it as an array.
- Return value:
string[]
type, a string array composed of tree node attributes.For example, for a file tree, a file node's attribute may contain the values of
[file name, file size, file type, last modified time]
.
expandable(): Promise<boolean>
Whether the tree node can be expanded, it can be expanded to true
, but not to be expanded to false
.
- Return value:
boolean
type, whether it can be expanded.
expanded(): Promise<boolean>
The expanded condition of the tree node is true
if expanded, and false
if not expanded (collapsed).
- Return value:
boolean
type, whether it has been expanded.
itemPath(): Promise<ItemPath>
The location of the tree node.
- Return value L:
ItemPath
type, representing the location of the tree node.
Chinese version click here.