Skip to content

QTableView多选

Published: at 05:25 AM | 2 min read

首先要了解它的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);
}