【QT 自研上位机 与 ESP32下位机联调>>>串口控制GPIO-基础样例-联合文章】

【QT 自研上位机 与 ESP32下位机联调>>>串口控制GPIO-基础样例-联合文章】

  • 1、概述
  • 2、实验环境
  • 3、 自我总结
  • 4、 实验过程
    • 1、验证上位机QT程序
      • 1、下载样例代码
      • 2、修改qt程序
      • 3、运行测试验证
    • 2、验证下位机ESP32程序
      • 1、下载样例代码
      • 2、更改ESP32代码,编译下载
      • 3、验证
    • 3、联合调试-ESP32和qt上位机
      • 1、硬件连接
      • 2、验证
  • 5、代码连接
  • 6、细节部分
      • (1)常见错误解决办法:
      • (2)ESP32工程下载后,先清理下
      • (3)逻辑分析仪,需要跳变信号触发
      • (4)逻辑分析仪,触发触发选择不点下面两个
  • 7、总结

1、概述

最为新手,想要快速入门相关设备,比如ESP32,可能最好的方式就是直接手动去敲一遍代码,而串口算是单片机入门中,必不可少的一个基础课程,很多通讯,以及打印各种信息,都需要,而加入一些交互,能让我们更好调试单片机。

我打算出3章,像之前STM32那种单片机,调试串口一样。
本次第三章,和上位机进行联合调试。

第一章,也就是串口基础篇,简单调试ESP32,进行交互。
第二章,将会结合GPIO,进行一些简单外围控制。
第三章,将会结合上位机,使用自制上位机进行联合调试。

2、实验环境

ESP32说明:ESP32-S3 是一款集成 2.4 GHz Wi-Fi 和 Bluetooth 5 (LE) 的 MCU 芯片,支持远距离模式 (Long Range)。ESP32-S3 搭载 Xtensa® 32 位 LX7 双核处理器,主频高达 240 MHz,内置 512 KB SRAM (TCM),具有 45 个可编程 GPIO 管脚和丰富的通信接口。ESP32-S3 支持更大容量的高速 Octal SPI flash 和片外 RAM,支持用户配置数据缓存与指令缓存。

硬件信息:开发板 ESP32-S3-DevKitM-1(EPS32-S3-wroom-1模块)
调试环境:Windows下
串口工具:USB转串口TTL/232等
其他硬件:逻辑分析仪,杜邦线,两个usb-type-c连接线等。
在这里插入图片描述

3、 自我总结

有了调试串口的经验,再加上调试IO的经验,其实我们就很容易合在一起,就像那个很有意思的笑话,苹果的英文单词和笔的单词,组合在一起的就是笔记本了。
如下,请允许我在原本应该严肃的科技博文中,加入一个搞笑的部分。
在这里插入图片描述
但是这个道理是相通的,我们学习一个东西的时候,其实一块一块学的,或者说以小见大。
举个例子,我们之前学习了ESP32的串口,

【PC电脑windows编写代码-学习uart0串口编写代码-串口程序-ESP32-简单通讯交互-基础样例学习】

同时又做了ESP32的IO实验,

【PC电脑windows-学习样例generic_gpio-拓展GPIO-ESP32的GPIO程序-问题解决-GPIO输出实验-基础样例学习(2)】

那么现在组合起来就可以了。

自己之前就有做联合文章的经历,从上位机,到下位机,一整条链路,一次性打通,学习每个部分,最后组合在一起,其实多少有些分繁琐而简化。

就像之前文章一样。

【QT 自研上位机 与 STM32F4xx下位机联调>>>can通信测试-基础样例-联合文章】

【QT 自研上位机 与 STM32F103下位机联调>>>串口uart通信测试-基础样例-联合文章】

也就有了本次实验,以及这篇文章。

4、 实验过程

1、验证上位机QT程序

上位机这块我们采用之前的串口工厂简单修改,来完成我们的目标。
【QT 5 调试软件+串口相关初试串口+基础样例】

1、下载样例代码

(1)下载代码
代码连接:https://download.csdn.net/download/qq_22146161/86722251
使用qt开,然后硬件转换器短接。
在这里插入图片描述
qt运行原件如下,可以看到能收到自己发出的“123”
在这里插入图片描述

2、修改qt程序

我们简单改写程序,发出990和991,好和ESP32配合

(1)ui界面修改
在这里插入图片描述
(2)转到槽函数
在这里插入图片描述
在这里插入图片描述

(3)加入代码
在这里插入图片描述

3、运行测试验证

在这里插入图片描述

2、验证下位机ESP32程序

样例用的下ESP32,如下文章中的。同样的也是验证下。

【PC电脑windows编写代码-ESP32-串口控制GPIO编写代码-简单通讯交互控制IO-进阶样例学习-2】

1、下载样例代码

代码链接:https://download.csdn.net/download/qq_22146161/88678030

2、更改ESP32代码,编译下载

我们在990这条命令上,专门做了个双IO拉低拉高,这样好检验。

#include <stdio.h>
#include <stdbool.h>
#include <unistd.h>
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "driver/uart.h"
#include "string.h"
#include "driver/gpio.h"#define TX_PIN 18
#define RX_PIN 19
#define BUF_SIZE 1024const char *expected_string0 = "990";
const char *expected_string1 = "991";
const char *expected_string2 = "992";
const char *expected_string3 = "993";
const char *expected_string4 = "994";
const char *expected_string5 = "995";
const char *expected_string6 = "996";#define GPIO_OUTPUT_IO_0    35
#define GPIO_OUTPUT_IO_1    36
#define GPIO_OUTPUT_IO_2    37
#define GPIO_OUTPUT_IO_3    38#define GPIO_OUTPUT_PIN_SEL  ((1ULL<<GPIO_OUTPUT_IO_0) |(1ULL<<GPIO_OUTPUT_IO_1) | (1ULL<<GPIO_OUTPUT_IO_2) | (1ULL<<GPIO_OUTPUT_IO_3)) // 配置GPIO_OUT位寄存器void gpio_init(void)
{gpio_config_t io_conf;  // 定义一个gpio_config类型的结构体,下面的都算对其进行的配置io_conf.intr_type = GPIO_INTR_DISABLE;  // 禁止中断  io_conf.mode = GPIO_MODE_OUTPUT;            // 选择输出模式io_conf.pin_bit_mask = GPIO_OUTPUT_PIN_SEL; // 配置GPIO_OUT寄存器io_conf.pull_down_en = 0;                   // 禁止下拉io_conf.pull_up_en = 1;                     // 禁止上拉gpio_config(&io_conf);                      // 最后配置使能
}void app_main(void) {gpio_init();// 配置UART参数uart_config_t uart_config = {.baud_rate = 115200,.data_bits = UART_DATA_8_BITS,.parity = UART_PARITY_DISABLE,.stop_bits = UART_STOP_BITS_1,.flow_ctrl = UART_HW_FLOWCTRL_DISABLE};uart_param_config(UART_NUM_0, &uart_config);// 设置UART1使用的TX和RX引脚uart_set_pin(UART_NUM_0, TX_PIN, RX_PIN, UART_PIN_NO_CHANGE, UART_PIN_NO_CHANGE);// 安装UART驱动程序,使用默认缓冲区大小uart_driver_install(UART_NUM_0, BUF_SIZE * 2, BUF_SIZE * 2, 0, NULL, 0);// 发送和接收数据的缓冲区uint8_t *data = (uint8_t *)malloc(BUF_SIZE);const char *test_str0 = "write_this_is_990";const char *test_str1 = "write_this_is_991";const char *test_str2 = "write_this_is_992";const char *test_str3 = "write_this_is_993";const char *test_str4 = "write_this_is_994";const char *test_str5 = "write_this_is_995";const char *test_str6 = "write_this_is_996";while (1) {// 发送数据const char *test_str = "Hello from UART01!";uart_write_bytes(UART_NUM_0, test_str, strlen(test_str));// 从UART接收数据int length = 0;ESP_ERROR_CHECK(uart_get_buffered_data_len(UART_NUM_0, (size_t *)&length));length = uart_read_bytes(UART_NUM_0, data, length, 20 / portTICK_PERIOD_MS);if (length > 0) {data[length] = 0; // 确保字符串以null终止printf("Received data: '%s'\n", (char *)data);gpio_set_level(GPIO_OUTPUT_IO_0, 0);            // 把这个GPIO输出地电平vTaskDelay(10 / portTICK_PERIOD_MS);gpio_set_level(GPIO_OUTPUT_IO_0, 1);          vTaskDelay(10 / portTICK_PERIOD_MS);//控制第一个IO上下if(strstr ((const char *)data, expected_string0)!=NULL ){uart_write_bytes(UART_NUM_0, test_str0, strlen(test_str0));gpio_set_level(GPIO_OUTPUT_IO_0, 0);            // 把这个GPIO输出地电平vTaskDelay(1000 / portTICK_PERIOD_MS);gpio_set_level(GPIO_OUTPUT_IO_1, 0);            // 把这个GPIO输出地电平vTaskDelay(1000 / portTICK_PERIOD_MS);gpio_set_level(GPIO_OUTPUT_IO_1, 1);            // 把这个GPIO输出地高平vTaskDelay(1000 / portTICK_PERIOD_MS);gpio_set_level(GPIO_OUTPUT_IO_0, 1);            // 把这个GPIO输出地高平vTaskDelay(1000 / portTICK_PERIOD_MS);printf("this is 990!");// break;}if(strstr ((const char *)data, expected_string1) !=NULL ){uart_write_bytes(UART_NUM_0, test_str1, strlen(test_str1));gpio_set_level(GPIO_OUTPUT_IO_0, 0);            // 把这个GPIO输出低电平printf("this is 991!");//  break;}//控制第二个IO上下if(strstr ((const char *)data, expected_string2)!=NULL ){uart_write_bytes(UART_NUM_0, test_str2, strlen(test_str2));gpio_set_level(GPIO_OUTPUT_IO_1, 1);            // 把这个GPIO输出高电平printf("this is 992!");//   break;}if(strstr ((const char *)data, expected_string3)!=NULL ){uart_write_bytes(UART_NUM_0, test_str3, strlen(test_str3));gpio_set_level(GPIO_OUTPUT_IO_1, 0);            // 把这个GPIO输出低电平printf("this is 993!");//   break;}//控制第三个IO上下if(strstr ((const char *)data, expected_string4)!=NULL ){uart_write_bytes(UART_NUM_0, test_str4, strlen(test_str4));gpio_set_level(GPIO_OUTPUT_IO_2, 1);            // 把这个GPIO输出高电平printf("this is 994");//   break;}if(strstr ((const char *)data, expected_string5)!=NULL ){uart_write_bytes(UART_NUM_0, test_str5, strlen(test_str5));gpio_set_level(GPIO_OUTPUT_IO_2, 0);            // 把这个GPIO输出低电平printf("this is 995!");//   break;}//单独功能if(strstr ((const char *)data, expected_string6)!=NULL ){uart_write_bytes(UART_NUM_0, test_str6, strlen(test_str6));//gpio_set_level(GPIO_OUTPUT_IO_2, 0);            // 把这个GPIO输出低电平printf("this is 996!");//   break;}}vTaskDelay(2000 / portTICK_PERIOD_MS);}
}

在这里插入图片描述

下载完了按下复位

3、验证

硬件连接

3/5V IN ---  ESP32-18
3V OUT  ---  ESP32-19
GND     ---  GND

在这里插入图片描述
然后使用一个串口软件打开,看看是否能收到消息。

在这里插入图片描述

3、联合调试-ESP32和qt上位机

1、硬件连接

其实到目前位置,硬件连接已经完成了。
当然我们还需要接上逻辑分析仪

3/5V IN ---  ESP32-18
3V OUT  ---  ESP32-19
GND     ---  GND//逻辑分析仪
GND  ---- GND
0通道 ---- ESP32-35
GND  ---- GND
1通道 ---- ESP32-36

2、验证

(1)上位机软件和逻辑分析仪截图说明
如下,为上位机发送990后,上位机>>>通过通讯>>>单片机>>>IO控制>>>逻辑分析仪,整条链路。
在这里插入图片描述
(1)代码和逻辑分析仪截图说明
这块要简单分析下代码,35GPIO先跳变了下,然后拉低3S,在此期间36GPIO拉低了1S。
在这里插入图片描述

5、代码连接

一套解决办法吧,需要代码的自取。
代码链接:https://download.csdn.net/download/qq_22146161/88689386

6、细节部分

(1)常见错误解决办法:

调试单片机的时候,或者说调试串口的时候,其实很难问题穷尽,但是一些方式,可以帮我们更快定位。

  1. UART配置错误:确保你的UART配置与你所使用的引脚和硬件设置相匹配。检查波特率、数据位、校验位和停止位是否正确配置。
  2. GPIO引脚不正确或被占用:检查你用作UART的GPIO引脚是否正确,并且没有被其他功能(如SPI、I2C或内置功能)占用。
  3. UART驱动安装问题:确保UART驱动正确安装,没有内存分配错误或其他问题。
  4. 缓冲区问题:检查是否有足够的空间在UART的发送缓冲区中存储要发送的数据。如果缓冲区已满,可能需要增加缓冲区大小或等待缓冲区可用。
  5. 硬件问题:检查你的ESP32开发板和任何连接的串行设备是否存在硬件故障。
    电源和接地问题:确保所有设备都有适当的电源和接地。

为了解决这个问题,可以尝试以下步骤:

  • 重新检查UART配置:确保UART的初始化和配置正确无误。
  • 检查GPIO引脚:验证所选择的GPIO引脚是否适合用作UART,且未被占用。
  • 检查驱动安装:确保使用 uart_driver_install 函数正确安装了UART驱动。
  • 增加缓冲区大小:如果需要,可以在调用 uart_driver_install 时增加缓冲区大小。
  • 硬件检查:检查ESP32开发板和相关硬件是否有任何明显的损坏或连接问题。

(2)ESP32工程下载后,先清理下

自己在下载过程中,发现直接编译也就是“idf.py build”的时候,会提示下,最好先清理下,然后重新编译。

在这里插入图片描述

(3)逻辑分析仪,需要跳变信号触发

如下,逻辑分析仪,在使用的时候,还是需要注意一下,它需要一个跳变信号,否则就会像下图一样,一直等待。
在这里插入图片描述
而且实际抓取信号,只后半部分,被拉高部分。
在这里插入图片描述
所以我们时间调试时,只要收到消息,先来个跳变信号触发下。
在这里插入图片描述

(4)逻辑分析仪,触发触发选择不点下面两个

实际想直接进行采集的,就把下面两个也点上了,实际测试应该是不选择下面两个
在这里插入图片描述

7、总结

如此一来,ESP32也有联合文章了。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【AI视野·今日NLP 自然语言处理论文速览 第六十七期】Mon, 1 Jan 2024

AI视野今日CS.NLP 自然语言处理论文速览 Mon, 1 Jan 2024 Totally 42 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Computation and Language Papers Principled Gradient-based Markov Chain Monte Carlo for Text Generation Authors Li Du, Afra Amini, Lucas…

权威测评首家通过!亚信安慧AntDB通过中国信通院数据库迁移工具专项测试

近日&#xff0c;亚信安慧数据库数据同步平台在中国信通院第17批“可信数据库”数据库迁移工具专项测试中&#xff0c;完全符合《数据库迁移工具能力要求》&#xff0c;成为首家通过标准测试的产品。这一成果标志着湖南亚信安慧科技有限公司&#xff08;简称“亚信安慧”&#…

js文件上传 分片上传/断点续传/极速秒传

(极速秒传)利用md5判断上传的文件是否存在 MD5信息摘要算法&#xff0c;一种被广泛使用的密码散列函数&#xff0c;可以产生出一个128位&#xff08;16字节&#xff09;的散列值&#xff08;hash value&#xff09;&#xff0c;用于确保信息传输完整一致。 每一个文件都会生成…

nvm如何使用

因涉及项目较多&#xff0c;node环境所需不同&#xff0c;项目依赖node环境出错原因&#xff0c;可借助nvm自由切换对应node环境&#xff0c;方便快捷。省去之前反复手动下载node版本&#xff0c;卸载安装。 nvm介绍自行搜索 nvm下载链接&#xff1a; https://github.com/co…

C++: 求1+2+3+...+n

int i 1; int sum 0; class Sum { public:Sum(){sum i;i;} };class Solution { public:int Sum_Solution(int n) {Sum a[n]; //调用n次sum的构造函数return sum;} };

NGUI基础-三大基础组件之Event System(Uicameras)

目录 主要作用 相关参数 (建议&#xff1a;红色是重点&#xff0c;黑色的了解即可&#xff09; Event Type Events go to Process Events in Event Mask​编辑 Debug Command Click Allow Multi Touch Auto Hide Cursor Sticky ToolTip/Long press ToolTip/ToolTip…

oracle物化视图

物化视图定义 视图是一个虚拟表&#xff08;也可以认为是一条语句&#xff09;&#xff0c;基于它创建时指定的查询语句返回的结果集&#xff0c;每次访问它都会导致这个查询语句被执行一次&#xff0c;为了避免每次访问都执行这个查询&#xff0c;可以将这个查询结果集存储到…

基于Flutter构建小型新闻App

目录 1. 概述 1.1 功能概述 1.2 技术准备 1.3 源码地址 2. App首页 2.1 pubspec依赖 2.2 热门首页组件 2.2.1 DefaultTabController 2.2.2 Swiper 2.3 新闻API数据访问 2.4 热门首页效果图 3. 新闻分类 3.1 GestureDetector 3.2 新闻分类效果图 4. 收藏功能 4…

【动态规划】LeetCode-10. 正则表达式匹配

10. 正则表达式匹配。 给你一个字符串 s 和一个字符规律 p&#xff0c;请你来实现一个支持 ‘.’ 和 ‘*’ 的正则表达式匹配。 ‘.’ 匹配任意单个字符‘*’ 匹配零个或多个前面的那一个元素 所谓匹配&#xff0c;是要涵盖 整个 字符串 s的&#xff0c;而不是部分字符串。 …

【开源】基于JAVA语言的智能教学资源库系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 课程档案模块2.3 课程资源模块2.4 课程作业模块2.5 课程评价模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 课程档案表3.2.2 课程资源表3.2.3 课程作业表3.2.4 课程评价表 四、系统展示五、核心代…

分布式(6)

目录 26.雪花算法如何实现的&#xff1f; 27.雪花算法有什么问题&#xff1f;有哪些解决思路&#xff1f; 28.有哪些方案实现分布式锁&#xff1f; 29.基于数据库如何实现分布式锁&#xff1f;有什么缺陷&#xff1f; 30.基于Redis如何实现分布式锁&#xff1f;有什么缺陷&…

GitHub Copilot 最佳免费平替:阿里通义灵码

之前分享了不少关于 GitHub Copilot 的文章&#xff0c;不少粉丝都评论让我试试阿里的通义灵码&#xff0c;这让我对通义灵码有了不少的兴趣。 今天&#xff0c;阿七就带大家了解一下阿里的通义灵码&#xff0c;我们按照之前 GitHub Copilot 的顺序分享通义灵码在相同场景下的…

uniapp微信小程序投票系统实战 (SpringBoot2+vue3.2+element plus ) -小程序首页实现

锋哥原创的uniapp微信小程序投票系统实战&#xff1a; uniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )_哔哩哔哩_bilibiliuniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )共计21条视频…

[蓝桥杯学习] 树状树组

lowbit操作 数字二进制表达中的最低位1以及后面所有的0&#xff0c;函数写法如下&#xff1a; int lowbit(int x){return x&-x;} 例如说&#xff0c;lowbit(0101100100) (100) lowbit(4) 4 lowbit(6) 2 时间复杂度o(1) 树状数组 应用 进行单点修改和区间查询…

本地计算机 上的 My5OL808 服务启动后停止,某些服务在未由其他服务或程序使用时将自动停止

客户反馈说mysql启动不了&#xff0c;报错信息&#xff1a; 本地计算机 上的 My5OL808 服务启动后停止&#xff0c;某些服务在未由其他服务或程序使用时将自动停止。 查了不少资料&#xff0c;最后分析问题是这样的&#xff0c;手动或者重复安装mysql时&#xff0c;创建了多个…

tp8/6 插件PhpOffice\PhpSpreadsheet导入表格

一、安装 composer require phpoffice/phpspreadsheet 官网&#xff1a;phpoffice/phpspreadsheet - Packagist 二、代码 <?php namespace app\services\upload\model; use app\services\BaseServices; use \PhpOffice\PhpSpreadsheet\Spreadsheet; use \PhpOffice\Php…

iOS苹果和Android安卓测试APP应用程序的区别差异

在移动应用开发中&#xff0c;测试是一个至关重要的环节。无论是iOS苹果还是Android安卓&#xff0c;测试APP应用程序都需要注意一些差异和细节。本文将详细介绍iOS和Android的测试差异&#xff0c;包括操作系统版本、设备适配、测试工具和测试策略&#xff0c;并回答一些新手容…

面部识别技术的突破:IP-Adapter-FaceID实现上传照片秒变多面人生

IP-Adapter-FaceID通过上传个人照片&#xff0c;仅需几分钟即可克隆一个高度真实的个性化面部图像。IP-Adapter-FaceID的独特之处在于&#xff0c;它不仅捕捉到个体的基本外貌特征&#xff0c;更深入地嵌入了面部识别模型的面部ID&#xff0c;使生成的图像在细节上更为准确和逼…

认识SpringBoot项目中的Starter

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 循序渐进学SpringBoot ✨特色专栏&…

[C#]yolov8-onnx在winform部署手势识别模型

【官方框架地址】 https://github.com/ultralytics/ultralytics.git 【算法介绍】 YOLOv8 是一个 SOTA 模型&#xff0c;它建立在以前 YOLO 版本的成功基础上&#xff0c;并引入了新的功能和改进&#xff0c;以进一步提升性能和灵活性。具体创新包括一个新的骨干网络、一个新…