QT窗体之间值的传递,多种方法实现

news2024/11/20 18:27:47

QT窗体之间值的传递,多种方法实现

  • 前言
  • [1] QT窗体之间值的传递,多种方法实现
    • 1、新建工程
    • 2、全局变量extern
    • 3、公共成员函数public
    • 4、信号与槽singnals
    • 5、总结与工程分享
      • 主窗口.cpp文件
      • 主窗口头文件
      • 子窗口.cpp文件
      • 子窗口头文件
  • [2] Qt在子窗口接收父窗口的信号(思路)
  • [3] Qt子窗口给父窗口传值(信号与槽机制)
    • 1、父窗口和子窗口名称介绍
    • 2、父窗口与子窗口内容介绍
    • 3、在父窗口中(Test_7.cpp),完整代码如下:
    • 4、父窗口中(Test_7.h),完整代码如下:
    • 5、子窗口(testnew.cpp),完整代码如下:
    • 6、子窗口(testnew.h),完整代码如下:
    • 7、程序运行结果,如下:
  • [4] qt 子窗口向父窗口发送信息
    • 子窗口 DatasetQueryConditionWgt.h
    • 子窗口 DatasetQueryConditionWgt.cpp
    • 父窗口 DataSetQueryWidget.h
    • 父窗口 DataSetQueryWidget.cpp
    • 父窗口向子窗口发送信息
      • 父界面.h
      • 父界面.cpp
      • 子界面.h
      • 子界面.cpp
    • 完整代码:
      • 主界面
      • 点击 show child
      • 父界面给子界面发消息
      • 子给父发
      • parentWidget.h
      • parentWidget .cpp
      • 子界面childWidget.h
      • childWidget .cpp
  • [5] Qt主窗口向子窗口传值
    • 1.通过Qt Designer设计主窗口与子窗口
    • 2.程序:
      • mainwindow.h
      • mainwindow.cpp
      • subwidge.h
      • subwidge.cpp
    • 3.程序运行结果:
  • [6] Qt窗体间传递变量方法总结
    • 1、使用QT中的Signal&Slot机制进行传值:
    • 2、使用全局变量
    • 3、使用public形式的函数接口
  • [7] qt 将主窗口的数据传到子窗口去

前言

在使用QT进行界面开发时,经常会出现父窗口和子窗口进行数据交互的情况。

比方说,单击父窗口上的一个控件,子窗口发生一些动作。或者单击子窗口上的一个控件,父窗口发生一些动作。

父窗口向子窗口传递数据较简单,单击父窗口上的控制时,直接使用槽函数调用子窗口的成员函数,然后传递参数即可,执行相应的动作即可。

主窗口向子窗口传值的过程中,由于子窗口里的控件是其私有成员,所以主窗口不能直接访问。解决的方法是在子窗口中定义一个公有函数,通过调用此函数实现私有成员的访问。

但单击子窗口时,向父窗口传递参数并调用父窗口执行一些操作,需要通过信号与槽函数来完成。

解决思路:

在子窗口类里面定义个信号,父窗口类里面定义个槽函数。

总结整体思路

1 子窗口给父窗口发送数据,我们可以在子窗口中定义信号,然后在父窗口中定义槽,在父窗口中将槽和信号连接起来,这样,你子窗口中的事件触发了信号,父窗口中的槽就会被执行,数据也就传递过来了,signal(参数1,参数2),slot(参数1,参数2)。

2 父窗口给子窗口发送数据,可以通过两种方式,第一种就是主窗口向子窗口传值的过程中,由于子窗口里的控件是其私有成员,所以主窗口不能直接访问。解决的方法是在子窗口中定义一个公有函数,通过调用此函数实现私有成员的访问(或者可以给自窗口的类中定义公有变量,然后在主窗口中改变此公有变量的值来达到传递的目的)。第二种就是信号和槽的方式,通过在子窗口中定义槽,在主窗口中定义信号,然后连接,利用参数传递数据。

[1] QT窗体之间值的传递,多种方法实现

在桌面程序中很多时候会出现很多窗口,各个窗口中免不了会有数据的传输。
下面给大家带来三种方法来实现QT的窗体数据传递。

1、新建工程

在这里插入图片描述
新建工程过后添加一个新的窗口到工程中,实际目录结构如上,然后我们实现按钮方式打开新建的窗,在主窗口中包含副窗口的头,再添加子窗口的类到主窗口的成员变量中,然后我们添加一个按钮并通过槽函数的方式打开子窗口。
在这里插入图片描述
到这里我们要实现传值的工程就搭建完成了下面开始传值的方法实现。

2、全局变量extern

通过全局变量的方法来设置子窗口的标题设置,首先我们需要在主窗口的CPP文件中添加一个全局变量,然后在子窗口的构造函数中我们使用这个全局变量来设置窗口标题。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
然后我们编译工程可以看到标题栏已经跟随主窗口CPP文件中的全局变量所更改了,下面我们将工程改变一下将子窗口类添加到父窗口成员变量中去方便我们调用。
在这里插入图片描述
在这里插入图片描述

3、公共成员函数public

接下来我们来实现通过调用公共成员函数的方法在主窗口中获取子窗口空间中的内容,我们先在主窗口和子窗口各添加一些控件,效果如下图:
在这里插入图片描述
在这里插入图片描述

然后我们在子页面添加一个公共成员函数用来获取编辑框的内容。

// 核心代码
class Dialog : public QDialog
{
    Q_OBJECT

public:
    explicit Dialog(QWidget *parent = nullptr);
    ~Dialog();

public:
    QString getFromText();

private:
    Ui::Dialog *ui;
};

QString Dialog::getFromText()
{
    return ui->lineEdit->text();;
}

然后我们在主窗口中来调用这个成员函数获得控件的值;

// 核心代码
void Widget::on_pushButton_2_clicked()
{
    ui->lineEdit->setText(w->getFromText());
}

在这里插入图片描述

4、信号与槽singnals

最后一个方法我们实现从子窗口来改变父窗口中编辑框中的内容,首先我们需要在子窗口类中发出一个senddata的信号,然后在主窗口中connect绑定这个信号在接受函数中将其内容设置到lineEdit上就可以实现这个效果,新建一个发送信号的按钮,然后再头文件中添加信号函数;

// 核心代码
signals:
   void sendDate(QString);


void Dialog::on_pushButton_clicked()
{
    sendDate(ui->lineEdit->text());
}

然后我们再主窗口中绑定该信号并将该信号传过来的内容设置到编辑框中;

// 核心代码
void Widget::on_pushButton_clicked()
{
    w = new Dialog();
    connect(w,SIGNAL(sendDate(QString)),this,SLOT(receiveData(QString)));
    w->show();
}

void Widget::receiveDate(QString date)
{
    ui->lineEdit->setText(date);
}

在这里插入图片描述

5、总结与工程分享

主窗口.cpp文件

#include "widget.h"
#include "ui_widget.h"

QString formTitle = "子窗口标题";

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
}

Widget::~Widget()
{
    delete ui;
}


void Widget::on_pushButton_clicked()
{
    w = new Dialog();
    connect(w,SIGNAL(sendDate(QString)),this,SLOT(receiveDate(QString)));
    w->show();
}

void Widget::on_pushButton_2_clicked()
{
    ui->lineEdit->setText(w->getFromText());
}

void Widget::receiveDate(QString date)
{
    ui->lineEdit->setText(date);
}

主窗口头文件

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include "dialog.h"

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

private slots:
    void on_pushButton_clicked();

    void on_pushButton_2_clicked();

    void receiveDate(QString date);
private:
    Ui::Widget *ui;
    Dialog *w;
};
#endif // WIDGET_H

子窗口.cpp文件

#include "dialog.h"
#include "ui_dialog.h"

extern QString formTitle;

Dialog::Dialog(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::Dialog)
{
    ui->setupUi(this);
    this->setWindowTitle(formTitle);
}

Dialog::~Dialog()
{
    delete ui;
}

QString Dialog::getFromText()
{
    return ui->lineEdit->text();;
}

void Dialog::on_pushButton_clicked()
{
    sendDate(ui->lineEdit->text());
}

子窗口头文件

#ifndef DIALOG_H
#define DIALOG_H

#include <QDialog>

namespace Ui {
class Dialog;
}

class Dialog : public QDialog
{
    Q_OBJECT

public:
    explicit Dialog(QWidget *parent = nullptr);
    ~Dialog();

public:
    QString getFromText();

private slots:
    void on_pushButton_clicked();

signals:
   void sendDate(QString);

private:
    Ui::Dialog *ui;
};

#endif // DIALOG_H

总结:QT的核心就是信号与槽,所以上面的方法我更推荐使用第三种。

完整工程下载:https://pan.baidu.com/s/1M8mTtkYD7wMTulvk-Ew5wA?pwd=j0q2 提取码:j0q2

[2] Qt在子窗口接收父窗口的信号(思路)

原文链接:https://blog.csdn.net/u013345672/article/details/103242109

1.在父窗口头文件:定义信号;

2.在需要发送的地方发送该信号;

3.在子窗口初始化类连接该信号,并实现槽函数;

 //在父类发送信号,
 //子窗口接收父窗口的消息,需要在子窗口中进行connect处理。
 connect(parent, SIGNAL(drawShapeOver()), this, SLOT(drawShape()));
///
void CellUi_Detection::drawShape()
{
	QMessageBox::information(this, "drawShape", "drawShape");
}

注意: 子窗口接收父窗口的消息,需要在子窗口中进行connect处理。

[3] Qt子窗口给父窗口传值(信号与槽机制)

原文链接:https://blog.csdn.net/Learning_Well/article/details/125552987

1、父窗口和子窗口名称介绍

父窗口:Test_7

子窗口:testnew

2、父窗口与子窗口内容介绍

子窗口:声明信号、发送信号

父窗口:声明槽函数,定义槽函数,connect连接

3、在父窗口中(Test_7.cpp),完整代码如下:

#include "Test_7.h"
 
Test_7::Test_7(QWidget *parent)
	: QMainWindow(parent)
{
	ui.setupUi(this);
	w = new TestNew;
	connect(ui.pushButton, SIGNAL(clicked()), this, SLOT(OnpushButton()));
	connect(w, SIGNAL(SignalSendQString_1(QString)), this, SLOT(SlotGetQString_1(QString)));
}
 
void Test_7::SlotGetQString_1(QString str)
{
	ui.textEdit->insertPlainText(str);
}
 
void Test_7::OnpushButton()
{
	w->show();
}

4、父窗口中(Test_7.h),完整代码如下:

#pragma once
 
#include <QtWidgets/QMainWindow>
#include "ui_Test_7.h"
#include "testnew.h"
 
class Test_7 : public QMainWindow
{
	Q_OBJECT
 
public:
	Test_7(QWidget *parent = Q_NULLPTR);
 
private:
	Ui::Test_7Class ui;
	TestNew *w;
 
	private slots:
	void SlotGetQString_1(QString str);
	void OnpushButton();
};

5、子窗口(testnew.cpp),完整代码如下:

#include "testnew.h"
 
TestNew::TestNew(QWidget *parent)
	: QWidget(parent)
{
	ui.setupUi(this);
	connect(ui.pushButton,SIGNAL(clicked()), this, SLOT(OnpushButton()));
}
 
TestNew::~TestNew()
{
 
}
void TestNew::OnpushButton()
{
	QString str = ui.textEdit->toPlainText();
	emit SignalSendQString_1(str);
}

6、子窗口(testnew.h),完整代码如下:

#pragma once
 
#include <QWidget>
#include "ui_testnew.h"
 
class TestNew : public QWidget
{
	Q_OBJECT
 
public:
	TestNew(QWidget *parent = Q_NULLPTR);
	~TestNew();
signals:
	void SignalSendQString_1(QString);
 
private:
	Ui::TestNew ui;
 
	private slots:
	void OnpushButton();
};

7、程序运行结果,如下:

在这里插入图片描述

[4] qt 子窗口向父窗口发送信息

原文链接:https://blog.csdn.net/fuyouzhiyi/article/details/120885420

场景:点击父窗口按钮1,弹出子窗口。点击子窗口查询按钮,隐藏子窗口并把查询结果显示在父窗口上。
参考文献Qt实例–主窗口和子窗口互发信号

简化需求为:子窗口点击按钮,向父窗口发送消息,并显示在子窗口上:

子窗口 DatasetQueryConditionWgt.h

要定义两个函数:

  1. 点击按钮,发送信号的槽函数SlotQueryBtnClicked(),注意带上slots
  2. 发送信息的函数 SignalQueryConditionBtnClicked(QVariantMap m_queryCondition),注意带上signals关键字
signals:
    void SignalQueryConditionBtnClicked(QVariantMap m_queryCondition);

protected slots:
    void SlotQueryBtnClicked();

子窗口 DatasetQueryConditionWgt.cpp

connect(ui.queryBtn, SIGNAL(clicked()), this, SLOT(SlotQueryBtnClicked()));//在子窗口的构造函数中写connect函数
...
void DatasetQueryConditionWgt::SlotQueryBtnClicked()
{
    ...//其他操作
    emit SignalQueryConditionBtnClicked( m_queryCondition);
}

父窗口 DataSetQueryWidget.h

申明槽函数,接受子窗口发送的信号

protected slots:
void DatasetQueryConditionWgtReceiveSignals(QVariantMap queryCondition);

父窗口 DataSetQueryWidget.cpp

connect(m_pWindow, &DatasetQueryConditionWgt::SignalQueryConditionBtnClicked, this, &DataSetQueryWidget::DatasetQueryConditionWgtReceiveSignals);
//参数分别是:子窗口实例化的对象指针,子窗口的信号函数,父窗口的对象指针,父窗口的槽函数
//一般在子窗口实例化,也就是new完之后 写connect

void DataSetQueryWidget::DatasetQueryConditionWgtReceiveSignals(QVariantMap queryCondition)
{
    m_pWindow->hide();
   queryCondition ···
}

坑一:
一开始我在父窗口的构造函数中写 connect,点击按钮没反应,因为构造函数运行时,子窗口还没有实例化,connect不起作用
new完之后再写就好了!!!

if(!m_pWindow)
			m_pWindow = new DatasetQueryConditionWgt(this);
        connect(m_pWindow, &DatasetQueryConditionWgt::SignalQueryConditionBtnClicked, this, &DataSetQueryWidget::DatasetQueryConditionWgtReceiveSignals);

坑二:
本来不打算用这个方法的,本来是打算直接在父窗口写子窗口的槽函数,但是在写connect时,发现 子窗口.ui 无法使用。这个是子窗口私有化的对象,所以connect无法奏效。
同事给了一种解决方案:在子窗口中设置getui函数获取ui,应该也可以,但是我没试。当然这个发送消息的方式也时同时告诉我的

父窗口向子窗口发送信息

父界面.h

 signals:
    void SignalAddDataset(QString datasetName);

父界面.cpp

#include "子界面.h"
//构造函数
父界面::父界面(QWidget *parent)
    : QWidget(parent)
{
   connect(this, &DataSetManageTab::SignalAddDataset, ui.dataSetManageWgt, &DataSetManagementWidget::ShowDatasetInfo);
    //connect(this, SIGNAL(SignalAddDataset(QString)), ui.dataSetManageWgt, SLOT(ShowDatasetInfo(const QString & )));
}

某某函数()
{
	emit SignalAddDataset(selectedDatasets[0]);
}

注:被注释掉的connect不好用,它能发送信号,但是子界面收不到。

子界面.h

public:
 void ShowDatasetInfo(const QString& strDatasetName);

子界面.cpp

 void dataSetManageWgt::ShowDatasetInfo(const QString& strDatasetName)
 {
     ......
 }

完整代码:

主界面

在这里插入图片描述

点击 show child

在这里插入图片描述

父界面给子界面发消息

在这里插入图片描述

子给父发

在这里插入图片描述

parentWidget.h

#pragma once
#include <QMainWindow>
#include "childWidget.h"
#include<QPushButton>
#include<QLabel>
#include "ui_parentWidget.h"
class parentWidget :
	public QMainWindow
{
	Q_OBJECT
public:
	parentWidget(QWidget *parent = Q_NULLPTR);
	~parentWidget();
signals:
	void sendTextToChild(QString);
protected slots:
	void showChildWidget();
	void showChildSay(QString);
	void sendChildWidget();
private:
	childWidget* m_childWidget =nullptr;
	QPushButton *button = nullptr, *button2 = nullptr;
	QLabel *label = nullptr;
private:
	Ui::MainWindow *ui;
};

parentWidget .cpp

#include "parentWidget.h"

#include<QGridLayout>

parentWidget::parentWidget(QWidget *parent ):QMainWindow(parent)
{
	ui->setupUi(this);
	 button = new QPushButton(this);
	button->setText("talk to child");
	 label = new QLabel(this);
	 label->setText("show child say");
	button2 = new QPushButton(this);
	button2->setText("show child widget");
	QGridLayout* glayReview = new QGridLayout(parent);
	glayReview->addWidget(button,0,0,1,1);
	glayReview->addWidget(label,1,0, 1, 1);
	glayReview->addWidget(button2,2,0, 1, 1);
	ui->centralwidget->setLayout(glayReview);
	connect(button2, SIGNAL(clicked()), this, SLOT(showChildWidget()));
	connect(button, SIGNAL(clicked()), this, SLOT(sendChildWidget()));


}
parentWidget::~parentWidget()
{

}

void parentWidget::showChildWidget()
{
	if (!m_childWidget)
	{
		m_childWidget = new childWidget();
	}
	connect(this, &parentWidget::sendTextToChild, m_childWidget, &childWidget::showParentSay);
	connect(m_childWidget, &childWidget::sendTextToParent, this, &parentWidget::showChildSay);
	m_childWidget->show();
}

void parentWidget::sendChildWidget()
{
	emit sendTextToChild("Hello child");
}

void parentWidget::showChildSay(QString str)
{
	label->setText(str);
}

子界面childWidget.h

#pragma once
#include <qwidget.h>
#include<QPushButton>
#include<QLabel>
#include"ui_childWidget.h"
class childWidget :public QWidget
{
	Q_OBJECT
public:
		childWidget(QWidget *parent = Q_NULLPTR);
		~childWidget();
signals:
	void sendTextToParent(QString);
public slots:
	void showParentSay(QString);
	void sendToParentWidget();

private:
	QPushButton *button=nullptr;
	QLabel *label = nullptr;
private:
	Ui::childWidget *ui;
};

childWidget .cpp

 #include "childWidget.h"
#include<QPushButton>
#include<QLabel>
#include<QGridLayout>
childWidget::childWidget(QWidget *parent):QWidget(parent)
{
	ui->setupUi(this);
	button = new QPushButton();
	button->setText("talk to Parent");
	label = new QLabel();
	label->setText("show parent say");
	QGridLayout* glayReview = new QGridLayout(parent);
	glayReview->setContentsMargins(10, 10, 10, 10);
	glayReview->addWidget(button,0,0, 1, 1);
	glayReview->addWidget(label,1,0, 1, 1);
	setLayout(glayReview);
	connect(button, SIGNAL(clicked()), this, SLOT(sendToParentWidget()));
}
childWidget::~childWidget()
{

}

void childWidget::showParentSay(QString str)
{
	label->setText(str);
}
void childWidget::sendToParentWidget()
{
	emit sendTextToParent("Hello parent");
}

[5] Qt主窗口向子窗口传值

原文链接:https://blog.csdn.net/qinqinxiansheng/article/details/104985044

主窗口向子窗口传值的过程中,由于子窗口里的控件是其私有成员,所以主窗口不能直接访问。解决的方法是在子窗口中定义一个公有函数,通过调用此函数实现私有成员的访问。话不多说,看实现过程:

1.通过Qt Designer设计主窗口与子窗口

主窗口MainWindow包含一个按钮pushButton和一个文本编辑lineEdit
在这里插入图片描述
子窗口SubWidge包含一个标签label
在这里插入图片描述

2.程序:

mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QPushButton>

namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private:
    Ui::MainWindow *ui;

    private slots :
    void buttonEvent();//点击按钮的槽函数
};

#endif // MAINWINDOW_H

mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "subwidge.h"

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    //连接信号与槽
    connect(ui->pushButton, SIGNAL(clicked()), this, SLOT(buttonEvent()));
}

MainWindow::~MainWindow()
{
    delete ui;
}

//点击按钮的槽函数,生成子窗口,并显示信息
void MainWindow::buttonEvent()
{
   //生成子窗口
  SubWidge *subw = new SubWidge();
  subw->show();
   //将主窗口的文本信息,传进子窗口
  subw->setText(ui->lineEdit->text());
}

subwidge.h

#ifndef SUBWIDGE_H
#define SUBWIDGE_H

#include <QWidget>

namespace Ui {
class SubWidge;
}

class SubWidge : public QWidget
{
    Q_OBJECT

public:
    explicit SubWidge(QWidget *parent = nullptr);
    ~SubWidge();
    void setText(QString str);

private:
    Ui::SubWidge *ui;
};

#endif // SUBWIDGE_H

subwidge.cpp

#include "subwidge.h"
#include "ui_subwidge.h"

SubWidge::SubWidge(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::SubWidge)
{
    ui->setupUi(this);
}

SubWidge::~SubWidge()
{
    delete ui;
}

 void SubWidge::setText(QString str)
 {
     ui->label->setText(str);
 }

3.程序运行结果:

主窗口输入一条文本后,点击按钮
子窗口弹出,label上显示该文本信息
在这里插入图片描述

[6] Qt窗体间传递变量方法总结

参考:http://blog.csdn.net/hanxing0/article/details/9087237

在写QT程序时,难免会碰到多窗体之间进行传值的问题。依照自己的理解,我把多窗体传值的可以使用的方法归纳如下:

1.使用QT中的Signal&Slot机制进行传值;
2.使用全局变量;
3.使用public形式的函数接口;
4.使用QT中的Event机制(这种没有把握,但是感觉应该是可以的),但是实现起来应该比前几种复杂,这里不做讨论。

下面分别进行讨论:

1、使用QT中的Signal&Slot机制进行传值:

QT中的Signal&Slot机制相比于MFC中的消息机制简单了许多,它保证了任何对象之间均可以通过这种方式进行通信,甚至可以得到消息的sender。这里就拿一个简单的窗体间传值作为例子。

首先看一下主窗体MainWindow:在设计器中拖拽一个Label和一个TextEdit控件到界面上,TextEdit用于显示传递过来的数据。
在这里插入图片描述
创建一个右下有两个按键的对话框,放置一个Label和一个LineEdit。
在这里插入图片描述
下面就是编码的操作了,我们需要在Dialog中声明一个信号,当用户点击OK时传递LineEdit中的内容到mainWindow中,具体的dialog.h代码为:

#ifndef DIALOG_H
#define DIALOG_H
 
#include <QDialog>
 
namespace Ui {
class Dialog;
}
 
class Dialog : public QDialog
{
    Q_OBJECT
    
public:
    explicit Dialog(QWidget *parent = 0);
    ~Dialog();
    
private:
    Ui::Dialog *ui;
signals:
    void  sendData(QString);
private slots:
    void on_buttonBox_accepted();
};
 
#endif // DIALOG_H

其中的signals:void sendData(QString)便是我们需要的信号函数,同时声明了一个槽函数void on_buttonBox_accepted();用于相应确定按钮的click事件。下面就是需要在该函数中产生一个信号。代码如下:

void Dialog::on_buttonBox_accepted()
{
    emit sendData(ui->lineEdit->text());
}

代码异乎寻常的简单,只需要用emit的方式调用sendData函数,将需要的参数传递进去即可。而MainWindow中则需要声明接收的槽函数,注意槽函数参数只能与信号函数少或相等,而不能多于信号函数参数个数。在MainWindow的头文件中声明槽函数:

private slots:
    void receiveData(QString data);

为了便于测试,我只在MainWindow的构造函数中创建了一个Dialog对象,并连接了信号和槽,具体为:

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    //信号槽方式下父子窗体传值的测试
    Dialog *dlg = new Dialog;
    //关联信号和槽函数
    connect(dlg,SIGNAL(sendData(QString)),this,SLOT(receiveData(QString)));
  // dlg->setModal(true); 不论是模态或者非模态都可以正常传值
    dlg->show();
}

这里,我没有将父窗口的指针传递到Dialog中,如new Dialog(this),这种方式下,实际上可以归结到第三类传值方式中去。因为此时,可以使用MainWindow中的父窗口的函数进行数据的赋值和操作。这里,可能还有一个问题就是,父窗口如何给子窗口传值,一方面,仍然可以使用信号和槽的方式进行,但是,我感觉更便利的方式倒是使用这种public接口的方式进行传值。这种来的更直接和明显。当然,可以看出Signal&Signal方式进行此类的处理会更有通用性。在receiveData(QString)的槽函数中进行接收到数据的处理,这里仅仅进行了简单的显示:

void MainWindow::receiveData(QString data)
{
    ui->textEdit->setText(data);
}

最后看下结果:
在这里插入图片描述
在这里插入图片描述
最终的结果,因为信号和槽可以是多对多的,所以,在类似多个窗体广播信息时,这种方式就很有用,当然也可以使用全局变量的形式。

2、使用全局变量

这里介绍另一种方式全局变量进行传值,在上一次的界面中的mainWindow和dialog中分别加入一个Label和LineEdit以及一个pushbutton。效果如:
在这里插入图片描述
具体实现为:在mainWindow.cpp文件中加入:

QString globaldata;        //声明一个全局变量用于窗体间传值

在全局传值按钮的clicked事件中对globaldata进行赋值:

void MainWindow::on_globalpb_clicked()
{
    globaldata = ui->lineEdit->text();
}

在Dialog.cpp文件中声明外部变量:

extern QString globaldata;

在全局传值按钮的clicked事件中对globaldata进行显示:

void Dialog::on_pushButton_clicked()
{
    ui->lineEdit_2->setText(globaldata);
}

这种方式,可以看到一些缺点,就是不容易对UI界面进行实时显示,但是这对于一个系统来讲也有一些优势,就是可以方便地将一个系统的配置分配到相关的UI界面中去,但是,同样的,也增加了程序之间的耦合性。

3、使用public形式的函数接口

使用public函数接口的方式,就牵扯到两个方向间的传值,父到子以及子到父窗口,通过这种方式都很容易做到,如子到父,可以在子窗体中实现一个public方法如prepareDoingData(&data),将需要处理的data的引用传递到子窗体,子窗体中可以对其进行操作,这里展示父到子的传值:

在Dialog界面中增加一个TextEdit用于显示最终传递的内容,并增加一个公有的方法:

public:
void setTextEditData(QString data);

void Dialog::setTextEditData(QString data)
{
    ui->textEdit->setText(data);
}

上面部分是在头文件中的内容,下面为在.cpp中的内容,而在mainwindow.cpp中只需要进行调用即可:

dlg->setTextEditData(QString("我来测试公有接口方式传值!"));

在这里插入图片描述
至此,三种传值的方式已经全部讲解完毕,具体在项目中国使用哪种方式进行传值,则要视具体情况而定。个人感觉,基本传值可以采用信号槽方式降低耦合,系统配置可以使用单例模式然后在各个界面中进行配置,而public接口方式则适用于父子间窗体传值。

[7] qt 将主窗口的数据传到子窗口去

原文链接

方式2.主要是通过connect绑定信号和槽函数的机制实现的。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/516450.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Node.js版本管理工具,我选择n

文件收录&#xff1a; 个人网址&#xff1a;https://linglan01.cn/ Github&#xff1a; https://github.com/CatsAndMice/blog/issues 为什么要管理Node.js版本&#xff1f;这是我们要先明白的点。 假设我电脑Node.js版本为v14.x&#xff0c;日常工作中可能会遇到以下场景&…

c#入门教程(有一定计算机基础的人看)

废话不说&#xff0c;有一定基础的人看&#xff0c;如java等程序员 c#是什么&#xff1f; 开发语言&#xff0c;为什么要学&#xff1f;主流游戏是用这个开发 c#怎么运行? c#微软做的&#xff0c;微软做了个.net framework&#xff0c;c#运行在这个之上。windows自带.net …

8. 100ASK_V853-PRO开发板支持MPP媒体处理平台

0.前言 ​ MPP 系统控制模块&#xff0c;根据芯片特性&#xff0c;完成硬件各个部件的复位、基本初始化工作&#xff0c;同时负责完成 MPP&#xff08;Media Process Platform 媒体处理平台&#xff09;系统各个业务模块的初始化、去初始化以及管理 MPP 系统各个业务模块的工作…

python基于LBP+SVM开发构建基于fer2013数据集的人脸表情识别模型是种什么体验,让结果告诉你...

本身LBPSVM是比较经典的技术路线用来做图像识别、目标检测&#xff0c;没有什么特殊的地方 fer2013数据集在我之前的博文中也有详细的实践过&#xff0c;如下&#xff1a; 《fer2013人脸表情数据实践》 系统地基于CNN开发实现 《Python实现将人脸表情数据集fer2013转化为图像…

IP网络电话呼叫转移设置

这里的网络电话呼叫转移设置&#xff0c;我们以IP电话系统用方位的网络电话机为例说明 通话转移 当用户正在与对方通话时&#xff0c;并希望将呼叫转移到其他号码&#xff0c;这里有两种方法来转移呼叫&#xff0c;出席移转和非出席移转。 出席移转 出席移转也被称为“礼貌…

条形码阅读器 CnetSDK Barcode Scanner SDK Crack

条形码阅读器组件SDK CnetSDK Barcode Scanner SDK 为.NET程序员提供了一个免费测试的条形码阅读器软件&#xff0c;称为.NET Barcode Scanner SDK。它在从许多图像文件中读取条形码和识别条形码方面非常有效。这个.NET条形码库支持最流行的线性和2D条形码&#xff0c;如QR码&a…

膨胀阀的结构和工作原理(详细篇)

膨胀阀的工作原理 编辑搜图 膨胀阀也称节流阀&#xff0c;是组成汽车空调制冷系统的主要部件&#xff0c;安装在蒸发器入口处&#xff0c;如图 所示&#xff0c;是汽车空调制冷系统的高压与低压的分界点。其功用是&#xff1a;把来自贮液干燥器的高压液态制冷剂节流减压&#…

第五十七章 Unity 混音器

本章节我们介绍Unity 混音器 (Audio Mixer)&#xff0c;它允许我们混合各种音频源&#xff0c;并对音频源进行统一控制或应用各种效果。在Unity中混音器是一种资源文件&#xff0c;可以右键Create创建AudioMixer文件。虽然它是一个文件&#xff0c;但是Unity提供了图形化界面来…

人大李崇轩:我的生成模型修炼之路丨智源大会嘉宾风采

导读 AIGC的飞速发展离不开生成模型、深度学习以及多模态学习等领域研究的不断累积&#xff0c;其中生成模型的原理与算法发展是不可或缺的一部分&#xff0c;如&#xff1a;生成对抗网络 GAN 及其一系列变体、变分自编码器 VAE 及其一系列变体、自回归模型 AR、流模型 FLOW &a…

考虑多能负荷不确定性的区域综合能源系统鲁棒规划(MatlabPython代码)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

Interiorai: 室内设计工具平台

【产品介绍】 Interiorai是一个可以让用户从自己的房间照片中生成不同风格的室内设计的在线平台。用户只需上传一张房间的照片&#xff0c;选择想要的设计风格和模式&#xff0c;就可以看到AI生成的室内设计效果&#xff0c;并且可以下载或分享。帮助用户快速找到装修或改造房间…

即时聊天app开发-即时通讯app开发方案分析

如今&#xff0c;即时聊天APP层出不穷&#xff0c;它已经成为人们日常生活中密不可分的社交工具。如今&#xff0c;即时聊天APP不仅是聊天工具&#xff0c;也是企业营销的利器。我们经常可以在聊天主页上看到一些广告。如有必要&#xff0c;用户可以直接点击广告了解详情。即时…

五、云对象存储以及课程分类管理模块

本项目的存储图片和音频文件都存储在腾讯云的服务器中&#xff0c;本章先介绍存储图片的方式。 存储桶文件创建&#xff1a; 存储桶项目存储内容&#xff1a; APPID和密钥管理&#xff1a; APPID和密钥是整个云存储最为重要的验证依据&#xff0c;在配置文件中应用。 现在简要…

超大规模数据库集群保稳系列之一:高可用系统

总第560篇 2023年 第012篇 基于过去多年在大规模数据集群保稳方面的实践经验&#xff0c;我们希望能够跟业界进行一些技术交流&#xff0c;美团技术团队举办了第75期技术沙龙。我们邀请到了美团研究员赵应钢担任出品人&#xff0c;同时请邀请到张洪、王占全、蔺瑞超、沈裕锋等4…

【Linux】进程信号(上)

文章目录 1.信号概念理解信号产生信号保存信号处理 2. 信号的产生证明输入 CTRL C 就是向前台进程发送信号signal 函数内部参数传递的理解对于信号自定义动作的捕捉问题 3.信号产生的方式1.从键盘输入2.使用系统调用向进程发送信号killraiseabort 3.由软件条件产生信号 1.信号概…

轻博客Plume的搭建

什么是 Plume &#xff1f; Plume 是一个基于 ActivityPub 的联合博客引擎。它是用 Rust 编写的&#xff0c;带有 Rocket 框架&#xff0c;以及 Diesel 与数据库交互。前端使用 Ructe模板、WASM 和SCSS。 反向代理 假设我们实际访问地址为&#xff1a; https://plume.laosu.ml…

Map和WeakMap对象的用法(JS)

&#x1f4dd;个人主页&#xff1a;爱吃炫迈 &#x1f48c;系列专栏&#xff1a;数据结构与算法 &#x1f9d1;‍&#x1f4bb;座右铭&#xff1a;道阻且长&#xff0c;行则将至&#x1f497; 文章目录 &#x1f338;Mapkey创建map的其他方式Map常用方法Map结构原生提供三个遍历…

项目成本管理

定义&#xff1a;项目各个成本的总和 作用&#xff1a;在预算范围内完成项目 考点&#xff1a; 直接成本是指一个由项目组承担的费用&#xff0c;例如员工的工资&#xff0c;电脑等硬件费用。 间接成本是指由多个项目组承担的费用&#xff0c;例如租金&#xff0c;水电费&am…

社交媒体中的“点赞”“喜欢”是如何存储在数据库中的?

你有没有想过 Instagram、Twitter、Facebook 或任何社交媒体平台如何跟踪谁喜欢你的帖子&#xff1f;让我们在这篇文章中弄清楚&#xff01; 1&#xff1a;序言 最近&#xff0c;我受邀在一个名为“CityJS”的活动中发言。但问题在于&#xff1a;我是 PHP 开发人员。我根本不懂…

Palo Alto Networks利用基于机器学习的自动化网络安全解决方案

“ Palo Alto Networks利用第三代英特尔至强可扩展处理器和部署在云中的英特尔软件&#xff0c;为其云端安全服务提供强有力的支持&#xff0c;从而提升机器学习和推断的性能。 面对恶意软件攻击的快速演变和难以捉摸的特性&#xff0c;企业网络安全团队面临着巨大的挑战。恶意…