Qt上位机软件串口通讯

        Qt与下位机通讯可以使用提供的串口通信的类QtSerialPort(串行端口类),QSerialPortInfo(串行端口信息类);

        

        串口通讯的操作流程为:

        1、设置串口端口号;(设置前需要检查系统内可用的com口)

        2、设置波特率,如9600,n,8,1;

        3、打开串口;

        4、读写串口通讯数据;

        5、关闭串口;

        下面,以串口助手为例,解释串口通讯设置使用方法;

        首先需要包含两个头文件:

        .pro文件中增加如下行;

              .h中增加槽函数声明,增加串口初始化函数声明,QSerialPort类的端口函数声明;

        下面来到主函数.cpp;首先构造函数中,需要进行系统初始化,也就是设置前文n,8,1;

        后面是对其他按钮进行槽函数的链接;

        然后查看可以的端口,并且使用for循环输出到界面列表控件的选项里;

        关闭端口,打开端口函数;

         通过write函数,进行串口数据的发送;下图提供了数据和文本两种发送的方式;        而接受数据,通过readAll函数进行;如下例子添加了文本还是数据显示方式的判断,将读到的数据通过insertPlainText插入到plainTextEdit中;

        感谢up:Qt上位机软件串口通讯,第四集_哔哩哔哩_bilibili

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt上位机中传输文件给单片机可以通过以下步骤实现: 1. 打开文件:使用QFile类打开需要传输的文件。 2. 读取数据:使用QDataStream类读取文件中的数据。 3. 将数据发送给单片机:使用串口通信将读取的数据发送给单片机。可以使用QSerialPort类实现串口通信。 4. 单片机接收数据:在单片机端实现串口通信,接收从上位机发送过来的数据。 5. 写入数据:将接收到的数据写入单片机的存储器中。 6. 关闭文件和串口:在传输完成后,关闭文件和串口。 下面是一个简单的示例代码: ```cpp QFile file("test.txt"); // 打开文件 if (file.open(QIODevice::ReadOnly)) { QDataStream in(&file); // 读取数据 QByteArray data = in.readAll(); file.close(); QSerialPort serial; serial.setPortName("COM1"); // 设置串口号 serial.setBaudRate(QSerialPort::Baud115200); // 设置波特率 if (serial.open(QIODevice::ReadWrite)) { serial.write(data); // 发送数据 serial.flush(); serial.close(); } } ``` 在单片机端,可以使用串口接收数据并将其写入存储器中: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdint.h> #include "stm32f4xx.h" #define BUFFER_SIZE 1024 uint8_t buffer[BUFFER_SIZE]; void USART2_IRQHandler(void) { if (USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) { buffer[index++] = USART_ReceiveData(USART2); } } int main(void) { USART_InitTypeDef USART_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2 | GPIO_Pin_3; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_PinAFConfig(GPIOA, GPIO_PinSource2, GPIO_AF_USART2); GPIO_PinAFConfig(GPIOA, GPIO_PinSource3, GPIO_AF_USART2); USART_InitStructure.USART_BaudRate = 115200; USART_InitStructure.USART_WordLength = USART_WordLength_8b; USART_InitStructure.USART_StopBits = USART_StopBits_1; USART_InitStructure.USART_Parity = USART_Parity_No; USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; USART_Init(USART2, &USART_InitStructure); NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); USART_Cmd(USART2, ENABLE); while (1) { // 等待接收数据 while (index < BUFFER_SIZE); // 将接收到的数据写入存储器中 // ... index = 0; } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值