您的位置:首页 > 其它

QSortFilterProxyModel

2015-03-31 23:13 555 查看

QSortFilterProxyModel

使用法发如下:

QTreeView *treeView = new QTreeView;

MyItemModel *sourceModel = new MyItemModel(this);

QSortFilterProxyModel *proxyModel = new QSortFilterProxyModel(this);

proxyModel->setSourceModel(sourceModel);

treeView->setModel(proxyModel);


在槽函数中设置过滤的正则表达式方法,然后选择过滤的列。

proxyModel->setFilterRegExp(QRegExp(".png", Qt::CaseInsensitive, QRegExp::FixedString));

proxyModel->setFilterKeyColumn(1);


当然也可以使用固定的字符串过滤。

proxyModel->setFilterFixedString(const QString & pattern)


点击表头排序view要将以下方法设置为true

treeView->setSortingEnabled(true);


要自定义排序方式,继承QSortFilterProxyModel,实现函数

bool lessThan(const QModelIndex &left, const QModelIndex &right) const


要实现多列过滤,继承QSortFilterProxyModel,实现函数

bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const**


以下两个方法是qt自带例子
customsortfiltermodel
中的实现方式。

bool MySortFilterProxyModel::lessThan(const QModelIndex &left,

const QModelIndex &right) const

{

QVariant leftData = sourceModel()->data(left);

QVariant rightData = sourceModel()->data(right);

if (leftData.type() == QVariant::DateTime) {

return leftData.toDateTime() < rightData.toDateTime();

} else {

QRegExp *emailPattern = new QRegExp("([\\w\\.]*@[\\w\\.]*)");

QString leftString = leftData.toString();

if(left.column() == 1 && emailPattern->indexIn(leftString) != -1)

leftString = emailPattern->cap(1);

QString rightString = rightData.toString();

if(right.column() == 1 && emailPattern->indexIn(rightString) != -1)

rightString = emailPattern->cap(1);

return QString::localeAwareCompare(leftString, rightString) < 0;

}

}


bool MySortFilterProxyModel::filterAcceptsRow(int sourceRow,

const QModelIndex &sourceParent) const

{

QModelIndex index0 = sourceModel()->index(sourceRow, 0, sourceParent);

QModelIndex index1 = sourceModel()->index(sourceRow, 1, sourceParent);

QModelIndex index2 = sourceModel()->index(sourceRow, 2, sourceParent);

return (sourceModel()->data(index0).toString().contains(filterRegExp())

|| sourceModel()->data(index1).toString().contains(filterRegExp()))

&& dateInRange(sourceModel()->data(index2).toDate());

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: