mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 14:25:27 +00:00
Add a new model: SsrfFilterProxyModel
Add a new Model, it's the QSortFilterProxyModel that accepts functions to filter / sort. so instead of creating a new class for each different sorting (overkill), now we can just create a function and pass to this class. I'll rework the filtering system of subsurface to use this - in the meantime I've created this to ease the creation of another filter: the dive sites by gps coordinates. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
5db6d41598
commit
ab32295f89
3 changed files with 76 additions and 0 deletions
|
@ -390,6 +390,7 @@ set(SUBSURFACE_MODELS_LIB_SRCS
|
|||
qt-models/diveplotdatamodel.cpp
|
||||
qt-models/divelocationmodel.cpp
|
||||
qt-models/divesitepicturesmodel.cpp
|
||||
qt-models/ssrfsortfilterproxymodel.cpp
|
||||
)
|
||||
source_group("Subsurface Models" FILES ${SUBSURFACE_MODELS})
|
||||
|
||||
|
|
42
qt-models/ssrfsortfilterproxymodel.cpp
Normal file
42
qt-models/ssrfsortfilterproxymodel.cpp
Normal file
|
@ -0,0 +1,42 @@
|
|||
#include "ssrfsortfilterproxymodel.h"
|
||||
|
||||
SsrfSortFilterProxyModel::SsrfSortFilterProxyModel(QObject *parent)
|
||||
: QSortFilterProxyModel(parent), less_than(0), accepts_col(0), accepts_row(0)
|
||||
{
|
||||
}
|
||||
|
||||
bool SsrfSortFilterProxyModel::lessThan(const QModelIndex& source_left, const QModelIndex& source_right) const
|
||||
{
|
||||
Q_ASSERT(less_than);
|
||||
const QAbstractItemModel *self = this;
|
||||
return less_than(const_cast<QAbstractItemModel*>(self), source_left, source_right);
|
||||
}
|
||||
|
||||
bool SsrfSortFilterProxyModel::filterAcceptsRow(int source_row, const QModelIndex& source_parent) const
|
||||
{
|
||||
Q_ASSERT(accepts_row);
|
||||
const QAbstractItemModel *self = this;
|
||||
return accepts_row(const_cast<QAbstractItemModel*>(self), source_row, source_parent);
|
||||
}
|
||||
|
||||
bool SsrfSortFilterProxyModel::filterAcceptsColumn(int source_column, const QModelIndex& source_parent) const
|
||||
{
|
||||
Q_ASSERT(accepts_col);
|
||||
const QAbstractItemModel *self = this;
|
||||
return accepts_col(const_cast<QAbstractItemModel*>(self), source_column, source_parent);
|
||||
}
|
||||
|
||||
void SsrfSortFilterProxyModel::setLessThan(less_than_cb func)
|
||||
{
|
||||
less_than = func;
|
||||
}
|
||||
|
||||
void SsrfSortFilterProxyModel::setFilterRow(filter_accepts_row_cb func)
|
||||
{
|
||||
accepts_row = func;
|
||||
}
|
||||
|
||||
void SsrfSortFilterProxyModel::setFilterCol(filter_accepts_col_cb func)
|
||||
{
|
||||
accepts_col = func;
|
||||
}
|
33
qt-models/ssrfsortfilterproxymodel.h
Normal file
33
qt-models/ssrfsortfilterproxymodel.h
Normal file
|
@ -0,0 +1,33 @@
|
|||
#ifndef SSRFSORTFILTERPROXYMODEL_H
|
||||
#define SSRFSORTFILTERPROXYMODEL_H
|
||||
|
||||
#include <QSortFilterProxyModel>
|
||||
|
||||
typedef bool (*filter_accepts_col_cb) (QAbstractItemModel *model,int sourceRow, const QModelIndex& parent);
|
||||
typedef bool (*filter_accepts_row_cb) (QAbstractItemModel *model,int sourceRow, const QModelIndex& parent);
|
||||
typedef bool (*less_than_cb) (QAbstractItemModel *model, const QModelIndex& left, const QModelIndex& right);
|
||||
|
||||
/* Use this class when you wanna a quick filter.
|
||||
* instead of creating a new class, just create a new instance of this class
|
||||
* and plug your callback.
|
||||
*/
|
||||
class SsrfSortFilterProxyModel : public QSortFilterProxyModel {
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
SsrfSortFilterProxyModel(QObject *parent = 0);
|
||||
virtual bool lessThan(const QModelIndex& source_left, const QModelIndex& source_right) const;
|
||||
virtual bool filterAcceptsRow(int source_row, const QModelIndex& source_parent) const;
|
||||
virtual bool filterAcceptsColumn(int source_column, const QModelIndex& source_parent) const;
|
||||
|
||||
void setLessThan(less_than_cb func);
|
||||
void setFilterRow(filter_accepts_row_cb func);
|
||||
void setFilterCol(filter_accepts_col_cb func);
|
||||
|
||||
private:
|
||||
less_than_cb less_than;
|
||||
filter_accepts_col_cb accepts_col;
|
||||
filter_accepts_row_cb accepts_row;
|
||||
};
|
||||
|
||||
#endif
|
Loading…
Add table
Reference in a new issue