当前位置: 首页 > news >正文

用QT实现MVP模式

近些天用qt 作项目,遇到参数界面.偷闲写个mvp模式示例.

mvp模式重要的有两点

1  低耦合: 界面与后端数据类,不直接引用,可方便替换.

2 形成界面驱动-界面更新的闭环.:通过函数指针类技术,让数据自动回流.

MVP (Model-View-Presenter)

视图(View):

  • 接收用户的交互请求并根據需求展示数据给用户
  • 响應的數据可以是一個Model或者多個Model的混合

主持人(Presenter):

  • View 和 Mode的連接器
  • 接收 View 的要求 并給对应的Model去處理

模型(Model):

  • 負責數据 (增加,删除,更改,查詢)
  • 相關的业务逻辑,而不是在Presenter(因為會使Presenter變得臃腫)

参考:

一文读懂MVC、MVP和MVVM架构

直接上代码,

QT5.9.0 ,C++11

view, 包括一个设置数据的接口与一个要求数据的信号(类似于函数指针);诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼诉讼

//.h
class DialogView : public QDialog
{Q_OBJECTpublic:explicit DialogView(QWidget *parent = nullptr);~DialogView();void UpdateVidw(UerData data);signals:void UpdateView_Signal();private slots:void on_btnRefresh_clicked();private:Ui::DialogView *ui;
};//.cpp
void DialogView::UpdateVidw(UerData data)
{this->ui->comboBox->setCurrentIndex(data.SelIdx);this->ui->lineEdit->setText(data.txt);this->ui->spinBox->setValue(data.num);this->ui->timeEdit->setTime(data.utime);this->ui->dial->setValue(data.SelNum);
}void DialogView::on_btnRefresh_clicked()
{emit this->UpdateView_Signal();
}

流通使用的数据结构

struct UerData
{
public:int SelIdx;QString txt;int num;QTime utime;int SelNum;
};

Model. 提供数据源

//.h
class DataModel
{
public:UerData data;void UpdateData();
};//.cpp
void DataModel::UpdateData()
{// 模拟从外网,下位机设备等拿取数据.qsrand(QTime::currentTime().msec());data.SelIdx = qrand()%3;data.txt = data.SelIdx == 1 ? "NUm1" : "deg2";data.utime = QTime::currentTime();data.num = qrand() % 1000;data.SelNum = qrand() % 100;
}

Presenter, 提供连接View 和model的方法

//.h
class Presenter : public QObject
{Q_OBJECT
public:explicit Presenter(DataModel* model, DialogView* view,  QObject *parent = nullptr);public slots:void fetchData();private:DataModel* m_model;DialogView* m_view;
};// .cpp
Presenter::Presenter(DataModel *model, DialogView *view, QObject *parent): QObject{parent}
{this->m_model = model;this->m_view = view;// 通过fetchData函数 ,绑定view与 model ,类似给函数指针赋值;QObject::connect(view, SIGNAL(UpdateView_Signal()),this, SLOT(fetchData()));
}void Presenter::fetchData()
{this->m_model->UpdateData();this->m_view->UpdateVidw(m_model->data);
}

使用代码:

    DialogView *dlg = new DialogView();DataModel *model = new DataModel();Presenter *p = new Presenter(model, dlg);dlg->exec();

最后实现效果如下:

点击"更新"按钮数据自动更新.

 

http://www.lryc.cn/news/142087.html

相关文章:

  • (2023)Linux安装pytorch并使用pycharm远程编译运行
  • poi带表头多sheet导出
  • RedisDesktopManager(redis客户端,可输入用户名密码)
  • 【Adobe After Effects】关于ae点击空格不会播放反而回退一帧的解决方案
  • Linux网络编程:多路I/O转接服务器(select poll epoll)
  • Mybatis系列原理剖析之项目实战:自定义持久层框架
  • 阿里云 Serverless 应用引擎 2.0,正式公测!
  • 西北大学计算机考研844高分经验分享
  • 【java并发编程的艺术读书笔记】volatile关键字介绍、与synchronized的区别
  • LinkedList的顶级理解
  • 再学http-为什么文件上传要转成Base64?
  • 使用oracleVM搭建虚拟机
  • 深入探讨C存储类和存储期——Storage Duration
  • 医学图像融合的深度学习方法综述
  • 【Qt学习】04:QDialog
  • 如何更好的进行异常处理
  • 若依微服务版部署到IDEA
  • Elasticsearch 入门安装
  • 【80天学习完《深入理解计算机系统》】第十一天 3.5 过程(函数调用)
  • LinuxUbuntu安装VMware tools Segmentation fault (core dumped)怎么解决
  • 002微信小程序云开发API数据库-迁移状态查询/更新索引
  • 十几款拿来就能用的炫酷表白代码
  • 证券低延时环境设置并进行性能测试
  • 百度工程师浅析解码策略
  • windows下实现查看软件请求ip地址的方法
  • 【JAVA】String 类
  • LoRA继任者ReLoRA登场,通过叠加多个低秩更新矩阵实现更高效大模型训练效果
  • Elasticsearch 8.X reindex 源码剖析及提速指南
  • 前端组件库造轮子——Input组件开发教程
  • Day04-Vue基础-监听器-双向绑定-组件通信