微信小程序蓝牙开发总结,含踩坑教训
接口总结
正常使用:
- 初始化(开启)蓝牙模块
wx.openBluetoothAdapter
- 搜索蓝牙设备(消耗大量资源,要及时结束)
wx.startBluetoothDevicesDiscovery
- 结束搜索
wx.stopBluetoothDevicesDiscovery
- 与蓝牙设备建立连接
wx.createBLEConnection
- 获取蓝牙设备的服务列表
wx.getBLEDeviceServices
- 获取蓝牙设备的某个服务的特征值列表
wx.getBLEDeviceCharacteristics
- 与特征值通信
- 启用/关闭某个特征值的 notify
wx.notifyBLECharacteristicValueChange
- 读取特征值数据(读取到的数据通过特征值变化事件返回)
wx.readBLECharacteristicValue
- 向特征值写入数据
wx.writeBLECharacteristicValue
- 启用/关闭某个特征值的 notify
- 断开与蓝牙设备的连接
wx.closeBLEConnection
- 停用(关闭)蓝牙模块
wx.closeBluetoothAdapter
事件监听:
- 搜索过程中发现新的蓝牙设备
wx.onBluetoothDeviceFound
- 蓝牙适配器状态变化
wx.onBluetoothAdapterStateChange
- 蓝牙设备连接状态变化
wx.onBLEConnectionStateChange
- 特征值变化(需开启notify)
wx.onBLECharacteristicValueChange
其他:
- 根据uuid获取已连接的设备
wx.getConnectedBluetoothDevices
- 获取当前蓝牙模块周期已发现的设备
wx.getBluetoothDevices
- 获取本机蓝牙适配器的状态
wx.getBluetoothAdapterState
踩坑总结
- 全局
- 初始化蓝牙模块后才能调用相关API
- 初始化之前可执行事件监听,但不会触发事件回调
- 初始化后,如果errCode=10001,那么其实此时小程序蓝牙模块已经初始化完成,可以调用API,也会有事件回调。
- iOS 上由于系统需要获取特征值实例,必须要调用获取设备服务和特征值的接口,使用获取到的
serviceId
和characteristicId
,才能对特征值进行read
、write
、notify
操作 - Android 上,部分机型获取设备服务时会多出
00001800
和00001801
UUID的服务,这是系统行为,注意不要使用这两个服务 - Android 上获取到的
deviceId
为设备 MAC 地址,iOS 上则为设备 UUID - iOS 上不同手机搜索到的
deviceId
是不同的 - 与蓝牙设备通信的 MTU(最大传输单元)系统限定为
20
字节,如果超过则会出错,这里应该根据蓝牙设备协议进行分片传输。 - 特征值的读写是二进制数据,
ArrayBuffer
类型
- 设备连接
- 必须成对地调用
createBLEConnection
和closeBLEConnection
接口 - Android 上,如果连续多次调用
createBLEConnection
,可能会导致系统持有同一设备多个连接的实例,导致调用 closeBLEConnection 的时候并不能真正地断开与设备的连接 - 如果未能及时关闭连接释放资源,容易导致
state 133 GATT ERROR
的异常 - 若小程序在之前已有搜索过某个蓝牙设备,并成功建立连接,可直接传入之前搜索获取的
deviceId
直接尝试连接该设备,无需进行搜索操作 - 蓝牙连接随时可能断开,建议监听
wx.onBLEConnectionStateChange
回调事件,当蓝牙设备断开时按需执行重连操作
- 必须成对地调用
- 设备搜索
- iOS里面蓝牙状态变化以后不能马上开始搜索,否则会搜索不到设备,必须要等待2秒以上
- Android 上,部分机型无定位权限或者是定位开关未打开时会搜不到设备。原因是蓝牙功能是可以获取到定位的,系统基于安全考量,使用蓝牙接口时必须要有定位权限
- 设备搜索占用大量资源,要及时关闭
wx.getBluetoothDevices
获取到的设备列表为蓝牙模块生效期间所有搜索到的蓝牙设备- 若在蓝牙模块使用流程结束后未及时调用
wx.closeBluetoothAdapter
释放资源,那么:- 可能不会发现新的设备,因为之前已搜索过
- 调用
wx.getBluetoothDevices
时,仍会返回之前的蓝牙使用流程中搜索到的蓝牙设备,即使设备已经不在用户身边,无法连接
- 蓝牙设备在被搜索到时,系统返回的
name
字段一般为广播包中的localName
字段中的设备名称,而如果与蓝牙设备建立连接,系统返回的name
字段会改为从蓝牙设备上获取到的GattName
。若需要动态改变设备名称并展示,建议使用localName
字段
- 向特征值写入数据
- 并行调用多次可能会导致写入失败
- 若单次写入数据过长,iOS 上存在系统不会有任何回调的情况(包括错误回调)
- 特征值必须支持
write
- 读取特征值数据
- 并行调用多次可能会导致读取失败
- 接口读取到的信息需要在
onBLECharacteristicValueChange
方法注册的回调中获取 - 特征值必须支持
read
- 启用/关闭notify
- 启用后才会触发特征值变化
- 监听到的消息要进行过滤处理,有些设备会抽风一样的发送同样的消息,需要在处理逻辑里面去重
- 开启notify以后并不能马上发送消息,蓝牙设备有个准备的过程,需要延迟1秒以上才能发送,否则会发送失败
- 特征值必须支持
notify
或者indicate
1.本站所有资源收集于互联网,仅用于学习和研究,若用于违法,与本站无关,仅限学习交流请勿用于商业用途。
2.会员在本站下载的VIP素材后,只拥有使用权,著作权归原作者及49vps所有。
3.VIP素材,未经合法授权,会员不得以任何形式发布、传播、复制、转售该素材,否则一律封号处理。
4.如果素材损害你的权益,请联系客服删除。
49资源网 » 微信小程序蓝牙开发总结,含踩坑教训
49资源网 » 微信小程序蓝牙开发总结,含踩坑教训