您可以使用递归函数来实现此目的。下面是一个可能的实现:
void collapseEmptyItems(QTreeWidgetItem *parent)
{
// 循环遍历所有子项
for (int i = 0; i < parent->childCount(); ++i) {
QTreeWidgetItem *item = parent->child(i);
if (item->childCount() == 0) { // 如果子项数量为0,则关闭该目录
item->setExpanded(false);
} else { // 否则继续检查子级项目
collapseEmptyItems(item);
}
}
}
在上面的代码中,我们首先循环遍历指定父级项目的所有子级项目。对于每个项目,我们检查其子级项目数是否为零。如果是,则将该项关闭;否则,我们递归调用 collapseEmptyItems() 函数以检查其所有子级项目。
要在目录关闭事件中使用此功能,请连接 QTreeWidget 的 itemCollapsed() 信号,并在槽函数中调用 collapseEmptyItems() 函数:
connect(myTreeWidget, &QTreeWidget::itemCollapsed, [=](QTreeWidgetItem *item){
collapseEmptyItems(item); // 关闭所有下级中 子项为0的目录
});
在上面的代码中,我们使用 Lambda 表达式将匿名函数与 itemCollapsed() 信号连接起来。当用户关闭任何目录时,该函数将自动调用并传递被折叠的项目作为参数。