stm32使用蓝牙串口HC-05来进行收发数据和控制的使用流程

硬件条件:

stm32F103的板子、HC-05的蓝牙、USB-TTL的插头、stlink。

整个过程是常用的控制系统的闭合回路,设计通信的收发,嵌入式动作的响应等。

开发过程的顺序:

作者在进行了很多次的类似开发,每次在蓝牙的通信方面遇到问题,由于系统的复杂,往往也很难快速的找到嵌入式系统中到底是软件还是硬件出现了问题。经过多次的实验,本文推荐下面的设计流程,能够最快的找到问题的所在。

1、首先第一点验证所有的线没有问题,作者有一次遇到这样的问题,简直是崩溃。

2、其次将蓝牙芯片用USB-TTL连接在电脑上,测试与串口助手通信有没有问题。

更新一波新问题:USB-TTL在电脑端进行通信时,选择3.3V,另外注意电源端的供电稳定,在通信格式上正点原子的接收函数中,每次接收到的内容会加1再储存。同时要注意最后一个接收内容,也即判断接收完成的标志是不会存储到接收内存中的。

(其中注意蓝牙的电源最好是5V,此处针对本硬件条件,低于5V会导致通信失败)

3、将嵌入式程序烧录进芯片中,利用USB-TTL连接嵌入式硬件平台到电脑,利用串口助手进行数据收发的测试,

其中注意端口、速率的选择

注意:接收的过程中,千万不要以空字符为接收结束的标志,系统里必须要发送了过去,程序才能自动识别,有些串口助手在发送字符串的时候,并不会在结尾自动加上空字符,它只会将字符一个一个发送出去。*这是我本次遇到的问题*

4、调完通信的问题后,接着调嵌入式的动作问题。以及今后在其中对接收数据的格式处理等。

5、程序中的速率改为9600较好,115200的接收速率有些手机上的蓝牙助手是无法接收的。

  • 9
    点赞
  • 80
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是一个基本的示例代码,用于将STM32F4与HC-05蓝牙模块配对并实现数据传输: ```c #include "stm32f4xx.h" #include "stm32f4xx_usart.h" #include "stm32f4xx_gpio.h" void USART_Configuration(void) { USART_InitTypeDef USART_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; // 使能USART1和GPIOA的时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE); // 配置USART1的TX引脚为复用功能 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; 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); // 将PA9引脚复用为USART1 GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_USART1); // 配置USART1的工作参数 USART_InitStructure.USART_BaudRate = 9600; 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(USART1, &USART_InitStructure); // 使能USART1 USART_Cmd(USART1, ENABLE); } void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; // 使能GPIOB的时钟 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE); // 配置GPIOB的Pin6为输出模式 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL; GPIO_Init(GPIOB, &GPIO_InitStructure); } void delay(__IO uint32_t nCount) { while (nCount--) { } } int main(void) { USART_Configuration(); GPIO_Configuration(); while (1) { // 检查串口接收缓冲区是否有数据 if (USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == SET) { // 从串口接收数据 uint16_t receivedData = USART_ReceiveData(USART1); // 将接收到的数据发送回去 USART_SendData(USART1, receivedData); while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET) { } } // 发送数据HC-05模块 GPIO_SetBits(GPIOB, GPIO_Pin_6); delay(0xFFFFF); GPIO_ResetBits(GPIOB, GPIO_Pin_6); delay(0xFFFFF); } } ``` 此示例代码初始化了USART1和GPIOB,并实现了数据收发。当接收数据时,它会将接收到的数据发送回去。发送数据HC-05模块时,它会通过GPIOB的Pin 6引脚发送脉冲信号。 请注意,此示例代码仅供参考,您可能需要根据您的具体硬件配置和需求进行适当的修改和调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值