首先要了解它的setSelectionBehavior和setSelectionMode这两个接口,接下来再来考虑选中的问题。查看官方文档,setSelectionBehavior用来设置选中的是单元格,行还是列,setSelectionMode用来设置用户点击后的界面响应:单选,多选,扩展选择(Ctrl+Shift键),相邻,不选中。这里仅介绍设置为ExtendedSelection mode后的多选问题。
当QTableView进行如下初始化后:
tableview->setSelectionBehavior(QAbstractItemView::SelectRows);
tableview->setSelectionMode(QAbstractItemView::ExtendedSelection);
用代码进行多选的时候,调用QTableView::selectRow或者tableview->selectionModel()->select都达不到我们的要求。
查看API,发现select有两种用法:
virtual void select(const QModelIndex &index, QItemSelectionModel::SelectionFlags command);
virtual void select(const QItemSelection &selection, QItemSelectionModel::SelectionFlags command);
之前我们使用的是上面一种,没错下面的接口才是我们需要的。看起来不知道怎么使用,下面是封装后的方法:
void selectMulRows(const QModelIndexList &indexes)
{
QItemSelectionModel* selection_model = tableview_->selectionModel();
if (indexes.isEmpty() || !selection_model || !model_) {
return;
}
QItemSelection selection;
foreach(QModelIndex index, indexes) {
QModelIndex left = model_->index(index.row(), 0);
QModelIndex right = model_->index(index.row(), model_->columnCount() - 1);
QItemSelection sel(left, right);
//将每一个单元格/每一行都作为一个QItemSelection 对象,并拼接到总的QItemSelection 对象中
selection.merge(sel, QItemSelectionModel::Select);
}
selection_model->select(selection, QItemSelectionModel::Select);
}