低成本打造全能蓝牙输入设备:ESP32无线控制方案全解析
ESP32 Mouse/Keyboard for BLE HID是一个基于ESP32的蓝牙低能耗(BLE)人机交互设备(HID)实现,支持键盘和鼠标功能。这个开源项目不仅提供了串行API,与Adafruit的EZKey HID兼容,还允许外部模块进行控制,为各种智能设备提供灵活、便捷的无线输入解决方案。
🌟 项目核心价值:重新定义无线控制体验
多平台兼容,无缝连接各种设备
经过严格测试,该项目已验证可在主流操作系统和设备上稳定运行:
| 设备类型 | 鼠标功能 | 键盘功能 |
|---|---|---|
| Windows 10/11 | ✅ 完美支持 | ✅ 完美支持 |
| macOS (Mojave及以上) | ✅ 完美支持 | ✅ 完美支持 |
| Linux (Debian/Ubuntu) | ✅ 完美支持 | ✅ 完美支持 |
| Android (6.0+) | ✅ 完美支持 | ✅ 完美支持 |
| iOS/iPadOS (13.3+) | ✅ 需辅助触控 | ✅ 文本输入支持 |
💡 小贴士:部分iPad设备可能会显示蓝牙性能警告,这是由于ESP32的WiFi模块干扰导致,可忽略此提示正常使用。
超低成本实现无线控制
相比购买商业无线键鼠套装,使用ESP32模块(约¥20-50)自制方案成本更低,且支持完全自定义功能。硬件设计文件完全开源,包含PCB设计图、BOM清单和3D打印模型。
🛠️ 零基础入门步骤:3步完成固件烧录
1️⃣ 搭建开发环境
首先安装ESP-IDF框架:
# 克隆ESP-IDF仓库
git clone --recursive https://gitcode.com/gh_mirrors/es/esp32_mouse_keyboard
cd esp32_mouse_keyboard
# 安装工具链(参考ESP-IDF官方文档)
2️⃣ 编译固件
# 使用IDF工具链编译
idf.py build
# 或使用Makefile编译
make
3️⃣ 烧录到ESP32
# 替换(PORT)为实际串口,如COM3或/dev/ttyUSB0
idf.py -p (PORT) flash
# 查看调试输出
idf.py -p (PORT) monitor
🎮 功能演示:轻松掌控你的设备
基础测试:通过串口控制
连接ESP32后,在监控终端输入以下指令测试:
| 按键 | 功能 | 描述 |
|---|---|---|
w/a/s/d |
鼠标移动 | 上/左/下/右移动30像素 |
l/r |
鼠标点击 | 左键/右键点击 |
q |
键盘测试 | 发送"y"字符(US布局) |
外部控制:通过UART接口
项目支持通过UART与外部微控制器通信,使用简单的命令协议:
# 设置设备名称
$NAME MyESP32HID
# 获取已配对设备
$GP
# 发送鼠标移动指令(自定义协议)
$MOVE 100 -50 # X+100, Y-50
📱 创新应用场景:解锁无限可能
1️⃣ 无障碍辅助设备
将传感器或语音识别模块连接到ESP32,为行动不便人士提供定制化输入方案。例如:
- 眼动追踪转鼠标控制
- 语音命令转键盘输入
- 呼吸传感器控制光标
2️⃣ 智能家居控制中心
通过自定义按键实现一键控制:
- 客厅影音系统遥控器
- 智能灯光场景切换
- 家庭影院环境控制
3️⃣ 嵌入式系统调试工具
在无外设场景下:
- 树莓派无头系统配置
- 工业设备参数调试
- IoT设备远程控制
🔧 硬件设计与组装指南
项目提供完整的硬件设计文件,包括KiCad原理图和PCB布局,硬件设计文件位于hardware/目录。
图:ESP32 miniBT模块组装示意图,包含蓝牙天线和I2S麦克风接口,展示了元件布局和组装步骤
主要硬件组件:
- ESP32-WROOM-32模块
- CMM-4030D-261 I2S麦克风(可选)
- 3.3V LDO稳压器
- 迷你USB接口
🚀 高级自定义开发指南
修改键盘布局
编辑main/hid_dev.c文件自定义按键映射:
// 示例:修改按键映射表
const uint8_t keyboard_report_map[] = {
// 标准US布局定义
0x05, 0x01, // Usage Page (Generic Desktop)
0x09, 0x06, // Usage (Keyboard)
// ...其他HID报告描述符定义
};
添加新设备类型
项目支持扩展为游戏手柄等其他HID设备,修改main/hid_dev.h添加新报告类型:
// 添加操纵杆报告ID
#define HID_RPT_ID_JOYSTICK_IN 0x03
// 定义报告结构
typedef struct {
int8_t x_axis;
int8_t y_axis;
// ...其他轴和按键定义
} joy_stick_report_t;
🤝 社区参与和支持
贡献代码
- Fork本仓库
- 创建特性分支
git checkout -b feature/amazing-feature - 提交更改
git commit -m 'Add some amazing feature' - 推送到分支
git push origin feature/amazing-feature - 创建Pull Request
问题反馈
- 设备兼容性测试报告
- 功能bug提交
- 新功能建议
📄 许可证信息
硬件设计遵循CERN OHL v1.2开源协议,软件部分采用MIT许可证。详细信息参见项目根目录下的LICENSE文件。
无论你是电子爱好者、开发者还是DIY达人,ESP32 BLE HID项目都能为你提供灵活强大的无线控制解决方案。立即开始你的创作,探索更多可能性!
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0190
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0113
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08