支持BLE设备接入“腾讯连连”小程序
132
doc/28.BLE_Device_Quick_Start.md
Normal file
@@ -0,0 +1,132 @@
|
||||
# 1 操作场景
|
||||
|
||||
使用BLE蓝牙模拟一款智能灯,配合“腾讯连连”小程序实现设备接入,物联网开发平台可以远程控制灯的亮度、颜色、开关,并实时获取智能灯上报到开发平台的数据。
|
||||
|
||||
本文档主要指导您如何使用NRF52832模组在物联网开发平台创建智能灯产品并通过手机接入。
|
||||
|
||||
|
||||
# 2 前提条件
|
||||
|
||||
为了通过下面的步骤快速理解该业务流程,需要做好以下准备工作:
|
||||
- 申请物联网开发平台服务。
|
||||
- 准备一块NRF52832开发板。
|
||||
- 下载最新版本代码。
|
||||
- 安装python、JLink驱动程序。
|
||||
|
||||
|
||||
# 3 操作步骤
|
||||
|
||||
## 3.1 控制台操作
|
||||
|
||||
### 3.1.1 新建项目
|
||||
1. 登录 [物联网开发平台控制台](https://console.cloud.tencent.com/iotexplorer),选择【新建项目】。
|
||||
2. 在新建项目页面,填写项目基本信息,完成后点击保存。
|
||||
- 项目名称:输入“智能灯演示”或其他名称。
|
||||
- 项目描述:按照实际需求填写项目描述。
|
||||

|
||||
|
||||
|
||||
### 3.1.2 新建产品
|
||||
1. 进入该项目的产品列表页面,单击【新建产品】。
|
||||
2. 在新建产品页面,填写产品基本信息,完成后点击保存。
|
||||
- 产品名称:输入“蓝牙智能灯”或其他产品名称。
|
||||
- 产品类型:选择“智慧生活—电工照明—灯”。
|
||||
- 设备类型:选择“设备”。
|
||||
- 认证方式:选择“密钥认证”。
|
||||
- 通信方式:选择“BLE”。
|
||||
- 其他选项保持默认。
|
||||

|
||||
|
||||
|
||||
### 3.1.3 创建数据模板
|
||||
1. 打开刚刚创建的【蓝牙智能灯】产品。
|
||||

|
||||
|
||||
2. 选择【数据模板】,点击【导入JSON】。
|
||||

|
||||
|
||||
1. 打开代码中的`examples\nimble_llsync\date_templatenrf52832.json`,如果出现乱码请将您的编辑器修改为utf8编码,将文件中的代码粘贴进来,点击【导入】。
|
||||

|
||||
|
||||
|
||||
### 3.1.4 交互开发配置
|
||||
配置产品在小程序端的控制面板、配网引导、快捷入口,若不配置则使用系统默认配置。
|
||||

|
||||
|
||||
|
||||
### 3.1.5 新建设备
|
||||
在设备调试页面中,单击【新建设备】,输入设备名“ble_device_01”或其他设备名称,点击【保存】。
|
||||

|
||||
|
||||
|
||||
|
||||
## 3.2 设备端操作
|
||||
|
||||
### 3.2.1 硬件简介与连接
|
||||
开发板实物如下:
|
||||

|
||||
|
||||
指示灯作用如下
|
||||
- LED1: 开关
|
||||
- LED2: action
|
||||
- LED3: replay
|
||||
- LED4: 未使用
|
||||
|
||||
1. 使用USB线连接开发板左上角串口。
|
||||
2. 使用JLink连接开发板右下角下载线接口。
|
||||
3. 打开左上角电源开关。
|
||||
4. 打开设备管理器,确保串口和JLink能够正常识别,若不能识别请重新安装驱动。
|
||||

|
||||
|
||||
### 3.2.2 准备软件环境
|
||||
1. 新买到的nrf52832开发板可能已经烧写了 NORDIC 官方蓝牙协议栈,需要进行擦除,否则会导致下载失败、程序异常或其他问题
|
||||
2. 启动 JFlash.exe,选择 File -> New project
|
||||

|
||||
3. 点击省略号添加设备
|
||||

|
||||
4. 在“Device”中输入nrf52832,选择具体芯片型号,例程中使用的为nRF52832_xxAA
|
||||

|
||||
5. 选择 Target -> Manual Programming -> Erase Chip 擦除芯片
|
||||

|
||||
6. 擦除完成后即可继续进行之后的开发
|
||||
|
||||
### 3.2.3 代码修改与烧录
|
||||
1. 打开工程`board\Nordic_NRF52832\KEIL\llsync\TencentOS_tiny.uvprojx`。
|
||||
2. 打开文件`ble_qiot_import.c`,找到以下三个宏并修改为你自己的设备信息。
|
||||

|
||||
3. 在【设备调试】页面中选择【设备信息】子页面,将【设备名称】、【设备密钥】、【产品ID】分别填入`DEVICE_NAME`,`SECRET_KEY`,`PRODUCT_ID`。
|
||||

|
||||
4. 编译下载并运行。
|
||||
|
||||
## 3.3 腾讯连连小程序调试
|
||||
1. 微信主页面下拉并搜索【腾讯连连】小程序。
|
||||

|
||||
2. 点击下方的【加号】添加设备。
|
||||

|
||||

|
||||
3. 待扫描到蓝牙设备后点击右侧的【连接】。
|
||||

|
||||
4. 在【我的设备】中打开刚刚添加的蓝牙设备。
|
||||

|
||||
5. 点击右侧的【立即连接】连接设备,如连接失败。
|
||||

|
||||
6. 连接成功后点击【电灯开关】,可以看到开发版上【LED1】随之变化。
|
||||

|
||||
7. 点击【亮度】或【颜色】按钮进行设置
|
||||
8. 查看串口打印,可以看到亮度、颜色设置成功
|
||||

|
||||
|
||||
# 4 Q&A
|
||||
Q: 实际产品中如何处理设备信息?
|
||||
A: 例程中 `DEVICE_NAME`, `SECRET_KEY`, `PRODUCT_ID` 直接写在代码中,产品中应保存在Flash中,同时修改`ble_qiot_import.c`中`ble_get_product_id()`,`ble_get_device_name()`,`ble_get_psk()`三个函数。
|
||||
|
||||
Q: LLSync SDK 需要多大的 Flash 来保存配置信息?
|
||||
A: 目前只需要不到32字节。
|
||||
|
||||
Q: 如果开发其他 BLE 芯片,有什么注意事项?
|
||||
A: `components\connectivity\qcloud_iot_explorer_ble\inc\ble_qiot_import.h` 为用户需要移植适配的接口,与蓝牙协议栈相关的接口在`ble_qiot_import.c`中已经完成了适配,用户仅需根据实际产品要开发`ble_write_flash()`,`ble_read_flash()`等接口。
|
||||
|
||||
# 5 参考资料
|
||||
[LLSync SDK](https://github.com/tencentyun/qcloud-iot-explorer-BLE-sdk-embedded) 内相关文档
|
||||
[LLSync SDK 接入指引](https://cloud.tencent.com/document/product/1081/48398)
|
||||
[LLSync SDK 使用参考](https://cloud.tencent.com/document/product/1081/48399)
|
BIN
doc/image/BLE/ble_product.png
Normal file
After Width: | Height: | Size: 14 KiB |
BIN
doc/image/BLE/com_debug.png
Normal file
After Width: | Height: | Size: 126 KiB |
BIN
doc/image/BLE/data_template.png
Normal file
After Width: | Height: | Size: 29 KiB |
BIN
doc/image/BLE/device_info.png
Normal file
After Width: | Height: | Size: 41 KiB |
BIN
doc/image/BLE/edit_device_info.png
Normal file
After Width: | Height: | Size: 24 KiB |
BIN
doc/image/BLE/import_json.png
Normal file
After Width: | Height: | Size: 22 KiB |
BIN
doc/image/BLE/jflash1.png
Normal file
After Width: | Height: | Size: 28 KiB |
BIN
doc/image/BLE/jflash2.png
Normal file
After Width: | Height: | Size: 4.5 KiB |
BIN
doc/image/BLE/jflash3.png
Normal file
After Width: | Height: | Size: 20 KiB |
BIN
doc/image/BLE/jflash4.png
Normal file
After Width: | Height: | Size: 40 KiB |
BIN
doc/image/BLE/jlink_driver.png
Normal file
After Width: | Height: | Size: 97 KiB |
BIN
doc/image/BLE/llsync1.jpg
Normal file
After Width: | Height: | Size: 25 KiB |
BIN
doc/image/BLE/llsync2.jpg
Normal file
After Width: | Height: | Size: 28 KiB |
BIN
doc/image/BLE/llsync3.jpg
Normal file
After Width: | Height: | Size: 24 KiB |
BIN
doc/image/BLE/llsync4.jpg
Normal file
After Width: | Height: | Size: 27 KiB |
BIN
doc/image/BLE/llsync5.jpg
Normal file
After Width: | Height: | Size: 28 KiB |
BIN
doc/image/BLE/llsync6.jpg
Normal file
After Width: | Height: | Size: 21 KiB |
BIN
doc/image/BLE/llsync7.jpg
Normal file
After Width: | Height: | Size: 22 KiB |
BIN
doc/image/BLE/llsync_gui.png
Normal file
After Width: | Height: | Size: 46 KiB |
BIN
doc/image/BLE/new_device.png
Normal file
After Width: | Height: | Size: 39 KiB |
BIN
doc/image/BLE/new_product.png
Normal file
After Width: | Height: | Size: 32 KiB |
BIN
doc/image/BLE/new_project.png
Normal file
After Width: | Height: | Size: 15 KiB |
BIN
doc/image/BLE/nrf52832_board.jpg
Normal file
After Width: | Height: | Size: 212 KiB |