QT_connnect 函数的简单应用_不同界面的实时通信过程

2024-03-04 06:18

本文主要是介绍QT_connnect 函数的简单应用_不同界面的实时通信过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

QT connnect 函数的简单应用——不同界面的实时通信过程

Connect函数介绍

如果说Qt实现的最巧妙的应用,那就说Connect函数(信号和槽机制)。

在Qt Assistant中Connect函数的形式为:

QMetaObject::Connection QObject::connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type = Qt::AutoConnection)

显然可以看到connect继承自QObject类。其中,包含四个指定参数

  • sender,发送方对象指针
  • signal,信号函数
  • receiver,接收方对象指针
  • method,槽函数(处理函数)

其中信号和槽就是整个Qt的核心,Qt使用信号和槽来进行对象间的通信。当一个特殊的事件发生时便可以发射一个信号,而槽就是一个函数,他在信号发射后被调来响应这个信号

除了上述官方的形式,connect函数调用亦可实现如下的形式

QObject::connect(Object1,SIGNAL(signal1),Object2,SLOT(slot1));//也可用lambda表达式实现
QObject::connect(Object1,SIGNAL(signal1),[=](){]);

当然信号和槽机制存在着优点和缺点:

优点

  • 类型安全。信号的参数类型和参数个数同接收该信号的槽的参数类型和参数个数是相同的,即需要关联的信号和槽的签名必须是等同的
  • 松散耦合:信号和槽机制减弱了Qt对象的耦合度。激发信号的Qt对象无须知道是那个对象的那个槽需要接收它发送的信号,它只需做的就是在适当的事件发送适当的信号就可以了,而不需要知道也不关心它的信号有没有被接收到,更不需要知道那个对象的那个槽接收到了信号。同样的对象的槽函数也无需知道什么信号关联了自己。

缺点

信号和槽机制增强了对象间通信的灵活性,然而同时伴随着一些性能的损失。同回调函数相比,信号和槽机制运行效率就相较而言有些慢。

用connect函数实现不同页面的通信

在实现例程之前,需明确emit,emit是Qt中的关键字,用以标记发送信号。

静态页面设计

新建两个ui界面,一个是主界面,一个是子界面

主界面

在这里插入图片描述

子界面

在这里插入图片描述

代码编写
主界面的代码
#include "widget.h"
#include "ui_widget.h"
#include<QDebug>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);setpara=new para();//connect 函数实现 子界面和主界面的实时显示connect(setpara,&para::sendPara,this,&Widget::receivePara);}Widget::~Widget()
{delete ui;
}
void Widget::on_pushButtonOpenPara_clicked()
{setpara->show();
}void Widget::receivePara(QStringList str)
{ui->paraLabel0->setText(str.at(0));ui->paraLabel1->setText(str.at(1));ui->paraLabel2->setText(str.at(2));ui->paraLabel3->setText(str.at(3));ui->paraLabel4->setText(str.at(4));ui->paraLabel5->setText(str.at(5));ui->paraLabel6->setText(str.at(6));ui->paraLabel7->setText(str.at(7));ui->paraLabel8->setText(str.at(8));ui->paraLabel9->setText(str.at(9));ui->paraLabel10->setText(str.at(10));ui->paraLabel11->setText(str.at(11));ui->paraLabel12->setText(str.at(12));ui->paraLabel13->setText(str.at(13));qDebug()<<"参数设置成功";}
子界面主要代码
#include "para.h"
#include "ui_para.h"para::para(QWidget *parent) :QWidget(parent),ui(new Ui::para)
{ui->setupUi(this);readCurrentPara();
}para::~para()
{delete ui;
}void para::readCurrentPara()
{beamModel=ui->paraCB1->currentText();singleWidth=ui->paraCB2->currentText();measureRange=ui->paraCB3->currentText();workFrequence=ui->paraCB4->currentText();rollCompensation=ui->paraCB5->currentText();initalGain=ui->paraSB6->text();HHMIN=ui->paraSB7->text();coverSector=ui->paraCB8->currentText();transmitPower=ui->paraCB9->currentText();TVGcurve=ui->paraCB10->currentText();uploadWavefrom=ui->paraCB11->currentText();automaticMode=ui->paraCB12->currentText();installationOffset=ui->paraSB13->text();HHMAX=ui->paraSB14->text();paraStr<<beamModel<<singleWidth<<measureRange<<workFrequence<<rollCompensation<<initalGain<<HHMIN<<coverSector<<transmitPower<<TVGcurve<<uploadWavefrom<<automaticMode<<installationOffset<<HHMAX;}void para::on_btnConfirm_clicked()
{this->close();
}void para::on_btnCancel_clicked()
{ui->paraCB1->setCurrentText(paraStr.at(0));ui->paraCB2->setCurrentText(paraStr.at(1));ui->paraCB3->setCurrentText(paraStr.at(2));ui->paraCB4->setCurrentText(paraStr.at(3));ui->paraCB5->setCurrentText(paraStr.at(4));ui->paraSB6->setValue(paraStr.at(5).toFloat());ui->paraSB7->setValue(paraStr.at(6).toFloat());ui->paraCB8->setCurrentText(paraStr.at(7));ui->paraCB9->setCurrentText(paraStr.at(8));ui->paraCB10->setCurrentText(paraStr.at(9));ui->paraCB11->setCurrentText(paraStr.at(10));ui->paraCB12->setCurrentText(paraStr.at(11));ui->paraSB13->setValue(paraStr.at(12).toFloat());ui->paraSB14->setValue(paraStr.at(13).toFloat());
}void para::on_btnApply_clicked()
{//首先将Stringlist置为空paraStr.clear();
//    qDebug()<<paraStr<<"为空";'readCurrentPara();QMessageBox::information(this,"设置成功","参数设置成功");emit sendPara(paraStr);
}

效果演示

在这里插入图片描述

这篇关于QT_connnect 函数的简单应用_不同界面的实时通信过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/772242

相关文章

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.