Qt - UI数据双向绑定简易实现

乍暖还寒时候,与上班提醒互道早安。

前言

自从前端大火了以后,UI数据双向绑定的ui框架愈发流行。作为前菜鸡安卓开发,我也是最近才知道谷歌还有推 Jetpack Compose 作为UI框架;其最大的亮点就是 数据双向绑定声明式UI。而作为现Qt开发,看到声明式UI的使用表示简直不要太爽啊!

实现声明式UI ≈ 实现一个 编译器,非我等俗人可简单实现。那就退而求其次,先用Qt实现 UI与·数据双向绑定

原理

查找了一下,实现数据绑定的做法有大致如下几种:

  • 发布者-订阅者模式
  • 脏值检查
  • 数据劫持

Qt 实现思路

首先明确我们需要实现什么:

实现一个UI组件,这个组件可实现数据双向绑定。我们更新绑定变量的时候,绑定这个变量的UI组件,数据也会同步更新。同理,我们直接修改UI组件的属性,例如滑动条的位置亦会同步修改变量值。

Qt - 一文理解信号槽机制(万字剖析整理) 中讲到 Qt的信号槽机制就有用到 发布-订阅模型。那么我们将通过信号槽实现。

随着而来的是,信号槽机制依赖于 QObject元对象系统。而我们绑定的变量可能是 intfloat之类。为了能使用信号槽的通讯机制,我们必须将基本数据类型再封装一次。然后在变量类改变时通知控件类,在控件类改变时通知变量类。

在Qt中,控件类的改变本身就有相应的 changed() 信号,所以我们只需要接起来即可。

接下来的问题是如何知晓变量类改变,答案是 重载赋值运算符

源码

/*! hslider.h */
#ifndef HSLIDER_H
#define HSLIDER_H

#include <QWidget>
#include <QSlider>
#include <QDebug>

class HInt : public QObject
{
    Q_OBJECT
public:
    explicit HInt(int x = 0){number = x;}
    void operator=(const HInt &newValue )
    { Q_EMIT(change(newValue.number)); number = newValue.number;}
signals:
   void change(int newValue);
public slots:
   void update(int newValue){ number = newValue; qDebug() << "HInt::update: " << newValue;}
private:
    int number;
};

class HSlider : public QWidget
{
    Q_OBJECT
public:
    explicit HSlider(QWidget *parent = nullptr);
    void Buid(HInt *newValue);
signals:
   void change(int newValue);
public slots:
    void update(int newValue);
private:
    QSlider* mSlider;
    HInt *mValue;
};

#endif // HSLIDER_H


/*! hslider.cpp */
#include "hslider.h"

HSlider::HSlider(QWidget *parent) : QWidget(parent)
{
    mSlider = new QSlider(this);
    connect(mSlider,&QSlider::valueChanged,this,&HSlider::change);
}

void HSlider::Buid(HInt *newValue){
    if(newValue){
        if(!mValue){
            disconnect(mValue,&HInt::change,this,&HSlider::update);
            disconnect(this,&HSlider::change,mValue,&HInt::update);
        }
        mValue = newValue;
        connect(mValue,&HInt::change,this,&HSlider::update);
        connect(this,&HSlider::change,mValue,&HInt::update);
    }
}

void HSlider::update(int newValue){
    mSlider->setValue(newValue);
    qDebug() << "HSlider::update" << newValue;
}

效果

在这里插入图片描述

一些想法

  • 这是一个简陋的封装及演示,有时候应该参考 QSlider 的实现自定义控件。
  • HInt 用起来让人很不爽,可能得找找有没有别的什么办法能监控到变量的改变(并不想用事件轮询)。或许我应该好好了解下 数据劫持脏值检查 看能不能找到一些实现思路。

参考鸣谢

Vue.js数据双向绑定实现

C++ 赋值运算符重载

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Qt是一款流行的跨平台开发框架,可以用于开发各种类型的应用程序,包括智能家居系统。Qt提供了丰富的图形界面和应用程序逻辑开发工具,使得开发者可以轻松地创建用户友好的智能家居应用。以下是Qt作为简易智能家居框架的几个特点: 1. 跨平台性:Qt支持多种操作系统,如Windows、Linux和macOS,可以在不同的设备上运行,比如台式电脑、智能手机和平板电脑。这意味着开发者可以使用同一套代码来实现智能家居应用的跨平台兼容性,减少开发工作量。 2. 图形界面设计:Qt提供了丰富的图形界面设计工具,开发者可以使用Qt的可视化编辑器来创建用户友好的界面。智能家居系统通常需要一个易于操作的界面来控制家里的各种设备,Qt的图形界面设计工具可以帮助开发者轻松创建这样的界面。 3. 功能丰富的库:Qt提供了许多现成的功能库,如网络通信、数据库访问、多媒体处理等。这些功能库可以帮助开发者快速构建智能家居系统的各个模块,如设备控制、场景切换和数据存储。 4. 强大的事件处理机制:智能家居系统需要对各种事件进行处理,如用户的点击、设备的状态变化等。Qt提供了灵活的事件处理机制,可以方便地响应和处理这些事件,使得智能家居系统更加智能和灵活。 总之,Qt作为简易智能家居框架,具有跨平台性、图形界面设计、功能丰富的库和强大的事件处理机制等优势,可以帮助开发者快速创建用户友好、功能强大的智能家居应用程序。 ### 回答2: Qt是一种流行的跨平台开发框架,它为开发人员提供了丰富的工具和功能,使他们能够创建各种各样的应用程序。在智能家居领域,Qt可以作为一种简易的框架来构建智能家居解决方案。 首先,Qt具有跨平台的特性,这意味着开发人员可以使用同一套代码在不同的操作系统上运行其应用程序。这对于智能家居系统非常重要,因为它们通常需要在多个设备和平台上运行。使用Qt,开发人员可以轻松地开发一次,并在不同平台上部署他们的应用程序。 其次,Qt提供了易于使用的图形用户界面(GUI)工具,使开发人员能够快速创建各种控件和界面元素。在智能家居系统中,有许多不同的设备和传感器需要进行交互和控制。Qt的GUI工具可以帮助开发人员创建直观和易于使用的用户界面,使用户可以轻松地管理和控制智能设备。 此外,Qt还提供了丰富的网络功能,使开发人员能够建立连接和通信。在智能家居系统中,各种设备和传感器需要相互通信,以实现自动化和远程控制。Qt的网络功能可以帮助开发人员轻松地建立设备之间的连接,实现数据传输和控制命令的发送。 最后,Qt还提供了强大的多媒体功能,可以用于处理音频和视频数据。在智能家居系统中,多媒体功能可以用于实现音乐播放、视频监控等功能。Qt的多媒体功能可以帮助开发人员轻松地处理和管理多媒体数据,为用户提供更好的体验。 综上所述,Qt作为一种简易的智能家居框架,具有跨平台能力、易用的GUI工具、丰富的网络功能和强大的多媒体功能。开发人员可以使用Qt来快速构建智能家居系统,并为用户提供更好的体验。 ### 回答3: Qt是一种跨平台的应用程序开发框架,简易智能家居框架指的是利用Qt开发的一种简单且智能的家居控制系统。这个框架可以让用户通过使用智能设备或者手机等终端设备来控制家中的各种设备,实现智能化的生活。 首先,这个框架可以提供一个直观易用的用户界面,让用户可以通过简单的操作就能控制家中各种设备。用户可以通过界面来控制灯光、温度、音乐、电视等各种家居设备的开关、亮度、颜色等参数。用户可以根据自己的需求自由定制界面的布局和样式,使其更符合个人喜好。 其次,这个框架可以实现智能化的控制逻辑。通过与传感器和执行器的连接,框架可以获取环境信息,例如温度、湿度、光线强度等,并根据用户的设定来智能地调节相应的家居设备。比如,可以设置在特定的时间或者特定的天气条件下自动开关灯光,或者根据家庭成员的习惯自动调整空调的温度,提高生活的舒适性。 另外,这个框架还可以实现设备之间的互联互通。通过适配不同的通信协议,比如Wi-Fi、蓝牙、红外等,框架可以将不同品牌、不同类型的智能设备连接在一起,并进行数据交换和联动控制。用户可以通过一个终端设备同时控制多个智能设备,实现一键控制多个设备的功能。 最后,这个框架还可以提供数据统计和分析的功能。框架可以记录各种设备的使用情况,并通过数据分析来提供用户的使用习惯和偏好,以及家居设备的能耗情况等信息,帮助用户优化家居设备的使用,节省能源和成本。 总之,Qt简易智能家居框架提供了丰富的功能和智能化的操作,使用户可以更加方便地控制家中的设备,提高生活的舒适度和便捷性。它不仅满足用户对智能家居的需求,还可以帮助用户节约能源和成本,是一种十分实用的智能家居解决方案。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值