首先,我们依旧需要先创建一个 QPushButton
按钮,并且还需要创建一个槽函数 searchitem(QModelIndex parent, QString txt)
来接收其发射的信号。
接下来,在槽函数 searchitem() 中,我们需要实现选择搜索结果和设置其背景色为红色的逻辑。具体实现如下:
void searchitem(QModelIndex parent, QString txt)
{
QItemSelectionModel *selModel = ui->tableView->selectionModel(); // 获取 QTableView 的选择模型
QSortFilterProxyModel *proxyModel = qobject_cast<QSortFilterProxyModel*>(ui->tableView->model()); // 获取数据代理模型
QModelIndexList indexList = proxyModel->match(proxyModel->index(0, 0), Qt::DisplayRole, QVariant::fromValue(txt), -1, Qt::MatchContains); // 搜索匹配项
foreach (QModelIndex idx, indexList) // 遍历匹配项
{
// 选中搜索结果,并设置背景色为红色
selModel->select(idx, QItemSelectionModel::Select | QItemSelectionModel::Rows);
ui->tableView->setStyleSheet("QTableView::item:selected {background-color: red;}");
}
// 这里可以增加其他逻辑
}
注意,我们先获取了 QTableView
的选择模型 selModel
和其数据代理模型 proxyModel
。然后通过代理模型的 match()
方法搜索匹配项,并在遍历匹配项时使用选择模型的 select()
方法选中这些项,并通过 setStyleSheet()
方法将其背景颜色设置为红色。
最后,在槽函数中,你还可以增加其他的逻辑,比如更新搜索结果的计数器、显示搜索结果的摘要信息等等。
最后,将按钮的 clicked() 信号连接到槽函数 searchitem() 上,就可以实现我们的需求了。具体实现如下:
// 创建 QPushButton 按钮
QPushButton* button = new QPushButton("Search");
// 创建槽函数
void searchitem(QModelIndex parent, QString txt)
{
// 在这里实现 searchitem() 槽函数的具体逻辑,包括选中项和设置背景色
}
// 连接 clicked() 信号和 searchitem() 槽函数
connect(button, &QPushButton::clicked, [=]() {
QModelIndex parent = QModelIndex();
QString txt = "example text";
searchitem(parent, txt);
});
本文福利,莬费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,C++设计模式,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击莬费领取↓↓