【Qt】【模型视图架构】代理模型示例

1. 基本排序/过滤模型Basic Sort/Filter Model Example

官方提供的基本排序/过滤模型示例说明了如何使用QSortFilterProxyModel执行基本的排序和过滤。

窗口界面显如下:

基本代理模型示例

在继承QWidget类的子类Widget中设计显示。从界面上可以看出总共有两个QGroupBox。上方的QGroupBox中是显示原始模型的树试图,下方的QGroupBox中是显示代理模型的树视图,并且可以交互式地选择使用的过滤模式、语法、哪一列、大小写是否敏感。

代码中,Widget类提供一个公共的函数setSourceModel(),在创建Widget对象后未显示窗口前,调用该函数,为两个树视图设置数据模型。

在main.cpp中向模型中添加数据。

参考官方示例编写的代码参考:https://github.com/Innern/Qt/tree/master/ModelView/Examples/02_BasicSortFilterModel

官方示例中Sorted/filtered Model组合框中使用的是网格布局,参考代码中使用垂直布局。

2. 自定义排序/过滤模型Custom Sort/Filter Model Example

官方提供的Custom Sort/Filter Model Example说明了如何使用QSortFilterProxyModel的子类为试图提供代理模型。

代理模型通过将源模型的索引映射到对应于不同位置的新索引供试图使用,从而转换源模型的结构。

如下图是基本排序/过滤模型与自定义排序/过滤模型示例应用程序窗口界面:

自定义代理模型示例

自定义代理模型中包括三个类:

  • FilterLineEdit,继承自QLineEdit类,实现行编辑器的更多操作,如上右图的Filter pattern设置。
  • MySortFilterProxyModel类继承自QSortFilterProxyModel,提供一个自定义的代理模型;
  • Widget类提供主窗口界面显示

FilterLineEdit类定义及实现

FilterLineEdit继承自QLineEdit,子类化行编辑器。

该类在左侧提供了一个工具按钮,该工具按钮包含一个菜单栏,菜单栏中可以选择过滤模型的模式。

使用Q_PROPETRY宏声明了支持元对象系统的属性,如下:

    Q_OBJECT
    Q_PROPERTY(Qt::CaseSensitivity caseSensitivity READ caseSensitivity WRITE setCaseSensitivity)
    Q_PROPERTY(PatternSyntax patternSyntax READ patternSyntax WRITE setPatternSyntax)
public:
    explicit FilterLineEdit(QWidget *parent = nullptr);

    Qt::CaseSensitivity caseSensitivity() const;
    void setCaseSensitivity(Qt::CaseSensitivity caseSensitivity);

    enum PatternSyntax{
        RegularExpression,
        Wildcard,
        FixedString
    };
    Q_ENUM(PatternSyntax)

    PatternSyntax patternSyntax() const;
    void setPatternSyntax(PatternSyntax syntax);

提供信号filterChanged(),当文本内容改变或选择的过滤选项改变时,触发该信号。

MySortFilterProxyModel类定义及实现

MySortFilterProxyModel类继承自QSortFilterProxyModel类。QAbstractProxyModel及其子类是从QAbstractItemModel派生来的,关于普通模型子类化的许多相同建议也适用于代理模型。

QSortFilterProxyModel的许多默认函数实现都是为了调用相关源模型中的等效函数而编写的。对于具有更复杂行为的源模型,可能需要覆盖这种简单的代理机制。

MySortFilterProxyModel类从QSortFilterProxyModel类派生,以确保筛选器能够识别有效的日期范围,并控制排序行为。

MySortFilterProxyModel类定义如下:

class MySortFilterProxyModel : public QSortFilterProxyModel
{
    Q_OBJECT
public:
    explicit MySortFilterProxyModel(QObject *parent = nullptr);

    QDate filterMinimumDate() const;
    void setFilterMinimumDate(const QDate &date);
    QDate filterMaximumDate() const;
    void setFilterMaximumDate(const QDate &date);

protected:
    // 仅接受具有有效日期的行
    bool filterAcceptsRow(int source_row, const QModelIndex &source_parent) const override;
    // 使模型能够按照发件人的电子邮件地址对其排序。
    bool lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const override;

private:
    // 判断输入的日期是否有效
    bool dateInRange(const QDate &date) const;

private:
    QDate minimumData;
    QDate MaximumDate;
};

详细代码参考:https://github.com/Innern/Qt/tree/master/ModelView/Examples/03_CustomSortFilterModel

  • 26
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt中的MVC(Model-View-Controller)模式是一种常用的软件架构模式,用于将应用程序的数据、用户界面和业务逻辑分离开来,以实现更好的代码组织和可维护性。 在Qt中,MVC模式可以通过自定义的控制器来实现。具体来说,Qt的MVC架构可以描述为Model/View,并通过自定义的控制器来实现Model/View/Controller的设计模式。 在这种架构中,Model负责管理应用程序的数据,View负责显示数据和与用户交互,而Controller负责处理用户输入并更新Model和View之间的关系。 通过使用MVC模式,可以实现以下优点: 1. 分离关注点:MVC模式将数据、用户界面和业务逻辑分离开来,使得代码更易于理解和维护。 2. 可扩展性:由于模块之间的松耦合性,可以更容易地添加新的功能或修改现有功能。 3. 可重用性:通过将数据和界面分离,可以更容易地重用模型视图组件。 4. 可测试性:由于模块之间的明确分离,可以更容易地对模型视图和控制器进行单元测试。 以下是一个简单的示例代码,演示了如何在Qt中实现MVC架构: ```cpp // Model class DataModel : public QObject { Q_OBJECT public: // 数据相关的方法和属性 }; // View class DataView : public QWidget { Q_OBJECT public: // 显示数据和处理用户交互的方法和属性 }; // Controller class DataController : public QObject { Q_OBJECT public: DataController(DataModel* model, DataView* view) : m_model(model), m_view(view) { // 处理用户输入并更新模型视图之间的关系 } private: DataModel* m_model; DataView* m_view; }; int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建模型视图和控制器 DataModel model; DataView view; DataController controller(&model, &view); // 显示视图 view.show(); return app.exec(); } ``` 这个示例代码展示了一个简单的MVC架构,其中Model负责管理数据,View负责显示数据和与用户交互,Controller负责处理用户输入并更新Model和View之间的关系。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值