当前位置: 首页 > article >正文

手把手教你用STM32F103C8T6和HC-06蓝牙模块,实现手机App远程控制LED灯

从零搭建STM32蓝牙LED控制系统硬件连接、代码解析与手机端交互全指南当你第一次看到手机App能远程控制LED灯亮灭时那种科技魔法成真的兴奋感正是嵌入式开发的魅力所在。本文将带你用最常见的STM32F103C8T6开发板俗称蓝莓派和HC-06蓝牙模块构建一个完整的无线控制项目。不同于单纯的理论讲解我们会从元器件选型开始逐步完成硬件连接、固件开发、指令协议设计直到手机端交互最终让你获得一个可展示的实际作品。1. 项目准备与硬件搭建1.1 元器件清单与选型建议准备以下核心组件总成本不超过50元主控芯片STM32F103C8T6开发板核心板尺寸仅53mm×22mm蓝牙模块HC-06从机模块注意区分HC-05主从一体模块外围电路LED灯×2建议不同颜色、220Ω限流电阻、杜邦线若干提示购买HC-06时认准背面有ZS-040标识的正品模块市面上存在兼容性差的仿制品。1.2 硬件连接示意图按以下方式连接电路使用开发板3.3V供电更稳定蓝牙模块引脚STM32连接点功能说明VCC3.3V电源正极GNDGND电源地TXDPA3(USART2_RX)蓝牙发送→单片机接收RXDPA2(USART2_TX)单片机发送→蓝牙接收LED连接方案// LED1 - PB8, LED2 - PB9 GPIO_InitStructure.GPIO_Pin GPIO_Pin_8 | GPIO_Pin_9; GPIO_InitStructure.GPIO_Mode GPIO_Mode_Out_PP; GPIO_Init(GPIOB, GPIO_InitStructure);1.3 电源方案优化常见问题排查若蓝牙模块频繁断开尝试在VCC与GND之间并联100μF电容避免使用开发板5V输出HC-06虽标称支持但实际工作不稳定用万用表测量电压确保在3.3V±0.2V范围内2. 蓝牙通信基础配置2.1 USART串口初始化在usart.c中配置USART2用于蓝牙通信void USART2_Init(uint32_t baudrate) { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); // PA2(TX)推挽输出PA3(RX)浮空输入 GPIO_InitStructure.GPIO_Pin GPIO_Pin_2; GPIO_InitStructure.GPIO_Mode GPIO_Mode_AF_PP; GPIO_InitStructure.GPIO_Speed GPIO_Speed_50MHz; GPIO_Init(GPIOA, GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin GPIO_Pin_3; GPIO_InitStructure.GPIO_Mode GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, GPIO_InitStructure); USART_InitStructure.USART_BaudRate baudrate; USART_InitStructure.USART_WordLength USART_WordLength_8b; USART_InitStructure.USART_StopBits USART_StopBits_1; USART_InitStructure.USART_Parity USART_Parity_No; USART_InitStructure.USART_Mode USART_Mode_Rx | USART_Mode_Tx; USART_Init(USART2, USART_InitStructure); USART_Cmd(USART2, ENABLE); }2.2 蓝牙AT指令配置通过串口调试助手完成基础配置波特率9600发送AT应返回OK修改模块名称ATNAMEBLUE_LED设置配对密码ATPIN1234查询版本ATVERSION注意HC-06仅支持特定AT指令集输入后需以\r\n结尾2.3 中断接收配置实现数据接收中断服务函数uint8_t bluetooth_rx_buffer[64]; uint8_t bluetooth_rx_index 0; void USART2_IRQHandler(void) { if(USART_GetITStatus(USART2, USART_IT_RXNE) ! RESET) { uint8_t ch USART_ReceiveData(USART2); bluetooth_rx_buffer[bluetooth_rx_index] ch; if(ch \n || bluetooth_rx_index sizeof(bluetooth_rx_buffer)-1) { bluetooth_rx_buffer[bluetooth_rx_index] \0; Process_Bluetooth_Command((char*)bluetooth_rx_buffer); bluetooth_rx_index 0; } } }3. 控制协议设计与实现3.1 自定义指令协议设计简洁的ASCII协议格式指令示例功能说明L1:1LED1亮L1:0LED1灭L2:TLED2切换状态S?:查询当前所有LED状态协议特点冒号分隔指令类型和参数状态查询返回格式L1:1,L2:0每条指令以换行符\n结束3.2 指令处理函数实现void Process_Bluetooth_Command(char* cmd) { if(strncmp(cmd, L1:, 3) 0) { GPIO_WriteBit(GPIOB, GPIO_Pin_8, cmd[3] 1 ? Bit_SET : Bit_RESET); USART_SendResponse(L1 set OK); } else if(strncmp(cmd, L2:T, 4) 0) { GPIO_WriteBit(GPIOB, GPIO_Pin_9, (GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_9) Bit_SET) ? Bit_RESET : Bit_SET); USART_SendResponse(L2 toggled); } else if(strncmp(cmd, S?:, 3) 0) { char status[32]; sprintf(status, L1:%d,L2:%d, GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_8), GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_9)); USART_SendResponse(status); } } void USART_SendResponse(char* msg) { while(*msg) { USART_SendData(USART2, *msg); while(USART_GetFlagStatus(USART2, USART_FLAG_TC) RESET); } USART_SendData(USART2, \n); }4. 手机端交互实现4.1 推荐App与配置Android平台选用Serial Bluetooth Terminal免费无广告连接步骤扫描设备选择BLUE_LED输入配对密码1234设置通信波特率9600关键配置发送新行启用字符编码ASCII终端回显启用4.2 自定义控制界面使用App的Custom buttons功能创建控制面板[LED1 ON] - 发送L1:1 [LED1 OFF] - 发送L1:0 [TOGGLE LED2] - 发送L2:T [STATUS] - 发送S?:4.3 高级功能扩展在main.c中添加定时状态上报void TIM3_IRQHandler(void) { if(TIM_GetITStatus(TIM3, TIM_IT_Update) ! RESET) { static uint8_t counter 0; if(counter 10) { // 每秒上报一次 counter 0; char report[32]; sprintf(report, STAT:L1:%d,L2:%d, GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_8), GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_9)); USART_SendResponse(report); } TIM_ClearITPendingBit(TIM3, TIM_IT_Update); } }5. 项目优化与调试技巧5.1 常见问题解决方案蓝牙无法连接检查电源电压≥3.3V确认TX/RX交叉连接重新烧录AT固件数据乱码核对双方波特率检查USART时钟配置添加软件去抖处理响应延迟优化中断优先级减少调试打印输出检查堆栈溢出5.2 功耗优化措施通过修改电路和代码降低功耗硬件层面在LED回路串联1kΩ电阻使用MOSFET代替直接驱动软件层面// 进入低功耗模式 void Enter_Stop_Mode(void) { RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE); PWR_EnterSTOPMode(PWR_Regulator_LowPower, PWR_STOPEntry_WFI); SystemInit(); // 唤醒后重新初始化时钟 }5.3 扩展思路将这个项目作为基础平台可以扩展增加PWM调光功能指令如L1:P50接入温湿度传感器实现环境监测开发iOS/Android专属App使用Flutter跨平台框架添加Wi-Fi网关实现互联网远程控制实际部署时发现用热熔胶固定蓝牙模块天线部分能提升信号强度约20%。对于需要长距离控制的场景建议选用Class1蓝牙模块理论传输距离100米。

相关文章:

手把手教你用STM32F103C8T6和HC-06蓝牙模块,实现手机App远程控制LED灯

从零搭建STM32蓝牙LED控制系统:硬件连接、代码解析与手机端交互全指南 当你第一次看到手机App能远程控制LED灯亮灭时,那种"科技魔法成真"的兴奋感,正是嵌入式开发的魅力所在。本文将带你用最常见的STM32F103C8T6开发板(…...

Win10环境下GY8508 CAN总线驱动安装全流程与哈希值校验绕过技巧

1. GY8508 CAN总线驱动安装前的准备工作 在工业自动化领域,GY8508 CAN总线设备是常见的通信接口模块。但在Windows 10系统上安装驱动时,很多工程师都会遇到哈希值校验失败的问题。我去年在给某汽车生产线调试设备时就遇到过这个坑,折腾了大半…...

【文献分享】CONCERT 在空间转录组学中预测了针对特定领域的扰动反应

文章目录介绍代码参考介绍 空间扰动转录组学用于测量基因或化学修饰如何改变基因表达,同时保持组织环境的完整性。扰动的结果取决于细胞的内在状态,也取决于这些影响在细胞微环境中的传播方式。 我们推出了 CONCERT 这款针对特定区域的生成模型&#xf…...

matlab 点云体素中心最近邻点下采样(详细过程版)

目录 一、算法原理 1、实现过程 二、代码实现 三、结果展示 博客长期更新,本文最近一次更新时间为:2026年4月10日。 一、算法原理 1、实现过程 点云体素最近邻点滤波核心思想是通过空间网格化,在每个网格(体素)内仅保留一个最具代表性的点,以达到简化点云、减少数据量的…...

从零到精通:Windows系统风扇控制终极方案深度解析

从零到精通:Windows系统风扇控制终极方案深度解析 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/Fan…...

医疗AI助手MedGemma X-Ray:一键部署,体验智能影像识别与分析

MedGemma X-Ray:一键部署,体验智能影像识别与分析 1. 医疗AI助手的革命性价值 在医学影像领域,每一张X光片都承载着关键的健康信息。传统影像分析高度依赖医生的经验积累,而MedGemma X-Ray的出现,为这一领域带来了全…...

芯驰X9车规级芯片实战:如何用6核Cortex-A55打造智能座舱(附开发板评测)

芯驰X9车规级芯片开发实战:从选型到多屏异显的智能座舱全流程解析 在智能汽车快速普及的今天,座舱系统的智能化程度已成为消费者购车的重要考量因素。作为国内领先的车规级芯片解决方案,芯驰X9凭借其6核Cortex-A55架构和丰富的接口资源&#…...

用WPF和OpenCVSharp从零搭建一个Vision Master风格的视觉软件(附完整源码)

从零构建工业级视觉处理软件:WPFOpenCVSharp实战指南 工业视觉检测系统正逐渐成为智能制造的核心组件,但市面上成熟的商业软件往往价格昂贵且难以定制。作为一名长期从事工业自动化开发的工程师,我经常遇到需要快速开发定制化视觉解决方案的场…...

别再傻傻分不清!一张图看懂EtherCAT从站Startup list和CoE-online的核心差异与应用选型

EtherCAT从站配置双刃剑:Startup list与CoE-online的实战抉择指南 第一次接触EtherCAT从站配置时,面对Startup list和CoE-online这两个选项,不少工程师都会陷入选择困难。这两种配置方式看似都能实现参数设定,但底层逻辑和适用场景…...

从OBD到UDS:一文搞懂ISO14229 0x19服务中排放与非排放DTC的查询差异与实战

从OBD到UDS:深度解析ISO14229 0x19服务中排放与非排放DTC的差异化处理 在汽车电子控制单元(ECU)的开发与测试中,诊断故障码(DTC)的管理一直是工程师面临的核心挑战之一。特别是随着全球排放法规的日益严格&…...

LAYONTHEGROUND景

一、什么是requests? requests 是一个用于发送HTTP请求的 Python 库。 它可以帮助你: 轻松发送GET、POST、PUT、DELETE等请求 处理Cookie、会话等复杂性 自动解压缩内容 处理国际化域名和URL 二、应用场景 requests 广泛应用于以下实际场景: …...

告别复杂配置:用MS-Swift + vLLM 5分钟搞定Qwen2.5-VL的API服务部署与调用

5分钟极速部署Qwen2.5-VL多模态API:MS-Swift与vLLM实战指南 当我们需要将多模态大模型快速集成到智能客服、内容审核或教育工具中时,传统部署流程往往让人望而却步——从环境配置到模型优化,再到API封装,每一步都可能成为项目落地…...

终极指南:如何用Python-for-Android将Python应用快速打包为Android APK

终极指南:如何用Python-for-Android将Python应用快速打包为Android APK 【免费下载链接】python-for-android Turn your Python application into an Android APK 项目地址: https://gitcode.com/gh_mirrors/py/python-for-android Python-for-Android&#…...

openpilot深度解析:开源自动驾驶系统的架构设计与实战应用

openpilot深度解析:开源自动驾驶系统的架构设计与实战应用 【免费下载链接】openpilot openpilot is an operating system for robotics. Currently, it upgrades the driver assistance system on 300 supported cars. 项目地址: https://gitcode.com/GitHub_Tre…...

宜搭低代码进阶实战:从判断题到复杂场景的构建指南

1. 从判断题到实战:宜搭低代码的核心组件解析 第一次接触宜搭低代码平台时,我和很多人一样被那些判断题绕得头晕。比如"自定义页面中的连接块、容器和布局容器组件都可以配置循环数据功能"这道题,看似简单却藏着三个关键知识点。在…...

LabVIEW声音采集避坑指南:从麦克风选型到.lvm文件存储,新手必看的5个实战细节

LabVIEW声音采集避坑指南:从麦克风选型到.lvm文件存储的5个实战细节 第一次用LabVIEW做声音采集时,我对着波形图上跳动的噪声信号发呆了整整两小时——采样率设对了,接线也没问题,但采集到的音频就像老式收音机调频不准时的杂音。…...

终极硬件控制指南:如何用OmenSuperHub完全掌控惠普暗影精灵性能

终极硬件控制指南:如何用OmenSuperHub完全掌控惠普暗影精灵性能 【免费下载链接】OmenSuperHub 使用 WMI BIOS控制性能和风扇速度,自动解除DB功耗限制。 项目地址: https://gitcode.com/gh_mirrors/om/OmenSuperHub 厌倦了官方软件Omen Gaming Hu…...

Dips实战指南:极坐标投影在结构面分析中的关键应用

1. 极坐标投影在结构面分析中的核心价值 第一次接触Dips软件时,我被它处理结构面数据的独特方式震撼了。传统直角坐标系下杂乱无章的测量数据,转换到极坐标系后突然呈现出清晰的规律性。这种转变就像把一堆散落的拼图块重新排列,瞬间显现出完…...

C# 14原生AOT调用Dify流式响应API:如何安全绕过HttpClientHandler AOT不兼容?微软.NET 9 Preview 7补丁已验证

第一章:C# 14 原生 AOT 部署 Dify 客户端 最佳实践C# 14 的原生 AOT(Ahead-of-Time)编译能力显著提升了 .NET 应用的启动性能与部署轻量化水平,结合 Dify 的开放 API 设计,可构建零依赖、秒级启动的跨平台客户端。本章…...

Superset开发环境搭建指南:从零开始本地部署

1. 认识Superset:为什么选择它? Superset是Apache基金会旗下的开源数据可视化工具,用Python编写,基于Flask框架。我第一次接触它是在2018年,当时团队需要替换昂贵的商业BI工具。经过对比测试,Superset的响…...

Springboot 实现多数据源(PostgreSQL 和 SQL Server)连接于

一、环境准备 Free Spire.Doc for Python 是免费 Python 文档处理库,无需依赖 Microsoft Word,支持 Word 文档的创建、编辑、转换等操作,其中内置的 Markdown 解析能力,能高效实现 Markdown 到 Doc/Docx 格式的转换,且…...

如何快速检测微信单向好友:免费工具WechatRealFriends使用完全指南

如何快速检测微信单向好友:免费工具WechatRealFriends使用完全指南 【免费下载链接】WechatRealFriends 微信好友关系一键检测,基于微信ipad协议,看看有没有朋友偷偷删掉或者拉黑你 项目地址: https://gitcode.com/gh_mirrors/we/WechatRea…...

HsMod终极指南:如何通过开源插件将炉石传说个性化体验提升5倍

HsMod终极指南:如何通过开源插件将炉石传说个性化体验提升5倍 【免费下载链接】HsMod Hearthstone Modification Based on BepInEx 项目地址: https://gitcode.com/GitHub_Trending/hs/HsMod HsMod是一款基于BepInEx框架的开源炉石传说插件,为技术…...

WAN2.2文生视频+SDXL Prompt风格保姆级教程:零基础5分钟生成你的第一段AI视频

WAN2.2文生视频SDXL Prompt风格保姆级教程:零基础5分钟生成你的第一段AI视频 1. 教程目标与准备工作 1.1 你能学到什么 通过本教程,你将掌握: 如何在5分钟内完成WAN2.2文生视频环境的搭建使用中文提示词直接生成高质量视频的完整流程SDXL…...

深度解析Cursor Pro激活器:3层架构突破AI代码编辑器限制的技术实现

深度解析Cursor Pro激活器:3层架构突破AI代码编辑器限制的技术实现 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reac…...

ComfyUI ControlNet预处理器:3步解锁AI绘画的精准控制力

ComfyUI ControlNet预处理器:3步解锁AI绘画的精准控制力 【免费下载链接】comfyui_controlnet_aux ComfyUIs ControlNet Auxiliary Preprocessors 项目地址: https://gitcode.com/gh_mirrors/co/comfyui_controlnet_aux 还在为AI生成图像时无法精确控制构图而…...

等了47年,苹果这台史上最强电脑,真的要逆天了!

嘿,距离 2026 年 6 月的 WWDC 开发者大会只剩不到两个月了,你准备好了吗?我桌上这台 M2 Pro Mac mini 已经勤勤恳恳服役了三年。但根据最新的风声,苹果即将在 6 月发布搭载 M5 Max 和 M5 Ultra 芯片的 Mac Studio。随着 Mac Pro 逐…...

Vue-Pure-Admin:现代化企业级Vue3管理后台架构深度解析与技术实践

Vue-Pure-Admin:现代化企业级Vue3管理后台架构深度解析与技术实践 【免费下载链接】vue-pure-admin 全面ESMVue3ViteElement-PlusTypeScript编写的一款后台管理系统(兼容移动端) 项目地址: https://gitcode.com/GitHub_Trending/vu/vue-pur…...

终极指南:如何用 Ice 重新定义 macOS 菜单栏使用体验

终极指南:如何用 Ice 重新定义 macOS 菜单栏使用体验 【免费下载链接】Ice Powerful menu bar manager for macOS 项目地址: https://gitcode.com/GitHub_Trending/ice/Ice 你是否曾经因为 Mac 顶部菜单栏过于拥挤而感到烦躁?那些不断堆积的应用图…...

从Visio到PPT:科研绘图工具选择的效率革命与实战避坑

1. 科研绘图工具变迁:为什么越来越多人放弃Visio? 十年前我刚读博士时,实验室师兄教我的第一件事就是用Visio画流程图。那时候觉得这个软件真神奇,拖拽几个方框就能做出漂亮的示意图。但最近三年,我发现身边90%的科研同…...