当前位置:   article > 正文

手把手教你使用--常用模块--HC05蓝牙模块,无线蓝牙串口透传模块,(实例:手机蓝牙控制STM32单片机点亮LED灯)_hc蓝牙助手

hc蓝牙助手

最近在学STM32,基本的学完了,想学几个模块来巩固一下知识,就想到了蓝牙模块。玩啥好难过有很多博客教怎么连的,但自己看起来还是有点糊涂。模块的原理和知识点我就不讲解了,这里我主要手把手记录一下我是如何对蓝牙模块进行学习和使用的。

所使用的资料和工具我会放在最后的链接里,大家有需要的可以自行下载。

模块名称:HC-05蓝牙串口通信模块

其他模块:USB转TTL模块、杜邦线、蓝牙串口助手app

蓝牙模块的前期调试

因为我们只是使用到蓝牙模块的透传功能,只需要用到4个引脚(RXT、TXD、GND、VCC)

先使用杜邦线将USB转TTL模块和HC-05蓝牙模块相连

两模块共电、共地、两模块的TX和RX交换相接(USB转TTL的TX(RX)接蓝牙的RX(TX))

如图所示:

然后将USB转TTL模块插到电脑上,通过串口助手进行调试。

蓝牙模块通讯模式有两种工作方式:命令响应工作模式和自动连工作模式(在自动连接工作模式下又可分为主、从和回环三种角色)

        ·当模块处于自动连接工作模式时,将自动根据事先设定的方式连接的数据传输;

        ·当模块处于命令响应工作模式时能执行AT命令,用户可向模块发送各种AT 指令,为模块设定控制参数或发布控制命令。

如何进入命令响应:

给模块上电即插USB的时候,按住蓝牙HC-05模块的那个小按键,此时模块进入AT模式

蓝牙模块上有一个小灯,灯快闪的时候,就是自动连接模式。慢闪的时候,就是命令响应工作模式

命令响应模式的波特率固定为38400,可以直接使用串口助手发送AT指令。

AT命令

AT指令不区分大小写,但是都要以回车符结尾

下面是常用的AT指令

 注意:AT+NAME?可能是没有返回数据的,我们直接设置蓝牙名称就可以了

我们接下来主要配置的就是

蓝牙名称和串口参数(波特率、停止位、校验位)

如图:

设置好之后把usb拔下来,重新上电的时候会默认为自动连接模式,此时使用手机的蓝牙助手对蓝牙模块进行连接,就可以通讯了。蓝牙助手我也会放在后面的资料链接里。

 将串口助手波特率设置为115200,在手机蓝牙中发送信息,会在串口助手中显示出来。

 最后,我们将在STM32开发板中连接蓝牙进行信息传输,控制LED灯

源码我将会放在后面的资料里一起打包。

这里我们使用串口1,因为串口1是我开发板的下载串口,所以要先下载代码之后再连接蓝牙模块的TX和RX,如果使用其他串口进行通讯改为其他串口即可,连接方式如图所示:

 蓝牙模块的RX连PA9,TX连PA10,VCC接板载的5V,GND接板子的GND即可

由于我使用的是野火的开发板,所用到的LED灯是个RGB灯,大家只需要初始化一下串口,然后看一下main函数里面的逻辑来实现自己板子的LED灯即可。也可以在中断函数里对灯进行操作

接下来就可以举一反三,使用蓝牙返回信息等操作了。

资料有需要自行提取:链接:https://pan.baidu.com/s/1iGrbTiivAsTwzd9wDLYFaQ 
提取码:3sp6

资料里面还有一个HC蓝牙助手,可以自定义按钮发送信息。

串口控制LED灯的代码如下:

usart.c:

  1. #include "bsp_usart.h"
  2. //static void NVIC_Configuration(void) //配置中断优先级,这里不使用中断,所以屏蔽
  3. //{
  4. // NVIC_InitTypeDef NVIC_InitStructure;
  5. //
  6. // /* 嵌套向量中断控制器组选择 */
  7. // NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  8. //
  9. // /* 配置USART为中断源 */
  10. // NVIC_InitStructure.NVIC_IRQChannel = DEBUG_USART_IRQ;
  11. // /* 抢断优先级*/
  12. // NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  13. // /* 子优先级 */
  14. // NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  15. // /* 使能中断 */
  16. // NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  17. // /* 初始化配置NVIC */
  18. // NVIC_Init(&NVIC_InitStructure);
  19. //}
  20. void USART_Config(void)
  21. {
  22. GPIO_InitTypeDef GPIO_InitStructure;
  23. USART_InitTypeDef USART_InitStructure;
  24. // 打开串口GPIO的时钟
  25. #include "stm32f10x.h" // Device header
  26. DEBUG_USART_GPIO_APBxClkCmd(DEBUG_USART_GPIO_CLK, ENABLE);
  27. // 打开串口外设的时钟
  28. DEBUG_USART_APBxClkCmd(DEBUG_USART_CLK, ENABLE);
  29. // 将USART Tx的GPIO配置为推挽复用模式
  30. #include "stm32f10x.h" // Device header
  31. GPIO_InitStructure.GPIO_Pin = DEBUG_USART_TX_GPIO_PIN;
  32. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  33. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  34. GPIO_Init(DEBUG_USART_TX_GPIO_PORT, &GPIO_InitStructure);
  35. // 将USART Rx的GPIO配置为浮空输入模式
  36. GPIO_InitStructure.GPIO_Pin = DEBUG_USART_RX_GPIO_PIN;
  37. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  38. GPIO_Init(DEBUG_USART_RX_GPIO_PORT, &GPIO_InitStructure);
  39. // 配置串口的工作参数
  40. // 配置波特率
  41. USART_InitStructure.USART_BaudRate = DEBUG_USART_BAUDRATE;
  42. // 配置 针数据字长
  43. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  44. // 配置停止位
  45. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  46. // 配置校验位
  47. USART_InitStructure.USART_Parity = USART_Parity_No ;
  48. // 配置硬件流控制
  49. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  50. // 配置工作模式,收发一起
  51. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
  52. // 完成串口的初始化配置
  53. USART_Init(DEBUG_USARTx, &USART_InitStructure);
  54. // // 串口中断优先级配置
  55. // NVIC_Configuration();
  56. //
  57. // // 使能串口接收中断
  58. // USART_ITConfig(DEBUG_USARTx, USART_IT_RXNE, ENABLE);
  59. // 使能串口
  60. USART_Cmd(DEBUG_USARTx, ENABLE);
  61. }
  62. /* 发送一个字节 */
  63. void Usart_SendByte(USART_TypeDef* pUSARTx, uint8_t data)
  64. {
  65. USART_SendData(pUSARTx, data);
  66. while( USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET );
  67. }
  68. /* 发送两个字节的数据 */
  69. void Usart_SendHalfWord(USART_TypeDef* pUSARTx, uint16_t data)
  70. {
  71. uint8_t temp_h,temp_l;
  72. temp_h = (data&0xff00) >> 8 ;
  73. temp_l = data&0xff;
  74. USART_SendData(pUSARTx, temp_h);
  75. while( USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET );
  76. USART_SendData(pUSARTx, temp_l);
  77. while( USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET );
  78. }
  79. /* 发送8位数据的数组 */
  80. void Usart_SendArray(USART_TypeDef* pUSARTx, uint8_t *array,uint8_t num)
  81. {
  82. uint8_t i;
  83. for( i=0; i<num; i++ )
  84. {
  85. Usart_SendByte(pUSARTx, array[i]);
  86. }
  87. while( USART_GetFlagStatus(pUSARTx, USART_FLAG_TC) == RESET );
  88. }
  89. /* 发送字符串 */
  90. void Usart_SendStr(USART_TypeDef* pUSARTx, uint8_t *str)
  91. {
  92. uint8_t i=0;
  93. do
  94. {
  95. Usart_SendByte(pUSARTx, *(str+i));
  96. i++;
  97. }while(*(str+i) != '\0');
  98. while( USART_GetFlagStatus(pUSARTx, USART_FLAG_TC) == RESET );
  99. }
  100. ///重定向c库函数printf到串口,重定向后可使用printf函数
  101. int fputc(int ch, FILE *f)
  102. {
  103. /* 发送一个字节数据到串口 */
  104. USART_SendData(DEBUG_USARTx, (uint8_t) ch);
  105. /* 等待发送完毕 */
  106. while (USART_GetFlagStatus(DEBUG_USARTx, USART_FLAG_TXE) == RESET);
  107. return (ch);
  108. }
  109. ///重定向c库函数scanf到串口,重写向后可使用scanf、getchar等函数
  110. int fgetc(FILE *f)
  111. {
  112. /* 等待串口输入数据 */
  113. while (USART_GetFlagStatus(DEBUG_USARTx, USART_FLAG_RXNE) == RESET);
  114. return (int)USART_ReceiveData(DEBUG_USARTx);
  115. }

 main.c

  1. int main(void)
  2. {
  3. uint8_t ch;
  4. USART_Config();
  5. LED_GPIO_Config();
  6. printf( "这是一个串口控制RGB灯的程序\n" );
  7. while (1)
  8. {
  9. ch = getchar();
  10. printf( "ch=%c\n",ch );
  11. switch(ch)
  12. {
  13. case '1': LED_RED;
  14. break;
  15. case '2': LED_GREEN;
  16. break;
  17. case '3': LED_BLUE;
  18. break;
  19. default: LED_RGBOFF;
  20. break;
  21. }
  22. }
  23. }

 led.c

  1. #include "bsp_led.h"
  2. /**
  3. * @brief 初始化控制LED的IO
  4. * @param 无
  5. * @retval 无
  6. */
  7. void LED_GPIO_Config(void)
  8. {
  9. /*定义一个GPIO_InitTypeDef类型的结构体*/
  10. GPIO_InitTypeDef GPIO_InitStructure;
  11. /*开启LED相关的GPIO外设时钟*/
  12. RCC_APB2PeriphClockCmd( LED1_GPIO_CLK | LED2_GPIO_CLK | LED3_GPIO_CLK, ENABLE);
  13. /*选择要控制的GPIO引脚*/
  14. GPIO_InitStructure.GPIO_Pin = LED1_GPIO_PIN;
  15. /*设置引脚模式为通用推挽输出*/
  16. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  17. /*设置引脚速率为50MHz */
  18. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  19. /*调用库函数,初始化GPIO*/
  20. GPIO_Init(LED1_GPIO_PORT, &GPIO_InitStructure);
  21. /*选择要控制的GPIO引脚*/
  22. GPIO_InitStructure.GPIO_Pin = LED2_GPIO_PIN;
  23. /*调用库函数,初始化GPIO*/
  24. GPIO_Init(LED2_GPIO_PORT, &GPIO_InitStructure);
  25. /*选择要控制的GPIO引脚*/
  26. GPIO_InitStructure.GPIO_Pin = LED3_GPIO_PIN;
  27. /*调用库函数,初始化GPIOF*/
  28. GPIO_Init(LED3_GPIO_PORT, &GPIO_InitStructure);
  29. /* 关闭所有led灯 */
  30. GPIO_SetBits(LED1_GPIO_PORT, LED1_GPIO_PIN);
  31. /* 关闭所有led灯 */
  32. GPIO_SetBits(LED2_GPIO_PORT, LED2_GPIO_PIN);
  33. /* 关闭所有led灯 */
  34. GPIO_SetBits(LED3_GPIO_PORT, LED3_GPIO_PIN);
  35. }
  36. /*********************************************END OF FILE**********************/

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号