zoukankan      html  css  js  c++  java
  • QT信号和槽参数传递复杂结构的数据

    https://blog.csdn.net/cLover_xiaolei/article/details/79017832

    QT信号和槽函数间参数传递只能是通用数据类型,有时信号和槽函数间需要传递map等结构复杂的数据。实现复杂结构数据传递的主体思路是:将复杂结构的数据包装成通用数据类型(QVariant)放入信号及槽函数中传递,在槽函数中使用时再转化为原来的数据类型。

    本次以传递参数类型:QMap<QString, int>为例。

    1、首先包含头文件:#include <QMetaType>, 在使用信号类(或主窗口类)的构造函数中,通过如下的方式注册数据类型:qRegisterMetaType<QVariant>("QVariant");

    2、然后分别申明信号和槽函数,并建立连接:

    创建信号:signals: void showMsgBox(QVariant, const QString &);

    创建槽:private slots: void sMsgBox(QVariant, const QString &);

    建立信号和槽连接:connect(this, SIGNAL(void showMsgBox(QVariant, const QString &)), this, SLOT(sMsgBox(QVariant, const QString &)), Qt::QueuedConnection);

    3、在信号发生处采用如下的方式进行数据包装:

    QMap<QString, int>allBackCode = thread->getAllBaceCode();//需要传递的数据,此处从线程中获取map数据获取(略)

    QVariant DataVar; //申明通用数据对象

    DataVar.setValue(allBackCode); //数据包装

    emit showMsgBox(DataVar, sheetName); //发送信号(其中sheetName为QString类型)

    4、在槽函数中进行数据还原:

    QMap<QString, int>mapBackCode = DataVar.value<QMap<QString, int>>();//还原为原来的数据结构类型

  • 相关阅读:
    68
    56
    Django manager 命令笔记
    Django 执行 manage 命令方式
    Django 连接 Mysql (8.0.16) 失败
    Python django 安装 mysqlclient 失败
    H.264 SODB RBSP EBSP的区别
    FFmpeg—— Bitstream Filters 作用
    MySQL 远程连接问题 (Windows Server)
    MySQL 笔记
  • 原文地址:https://www.cnblogs.com/Vancamel/p/11254051.html
Copyright © 2011-2022 走看看