49vps
模板家园

微信小程序蓝牙开发总结,含踩坑教训

接口总结

正常使用:

  1. 初始化(开启)蓝牙模块wx.openBluetoothAdapter
  2. 搜索蓝牙设备(消耗大量资源,要及时结束)wx.startBluetoothDevicesDiscovery
  3. 结束搜索wx.stopBluetoothDevicesDiscovery
  4. 与蓝牙设备建立连接wx.createBLEConnection
  5. 获取蓝牙设备的服务列表wx.getBLEDeviceServices
  6. 获取蓝牙设备的某个服务的特征值列表wx.getBLEDeviceCharacteristics
  7. 与特征值通信
    • 启用/关闭某个特征值的 notify wx.notifyBLECharacteristicValueChange
    • 读取特征值数据(读取到的数据通过特征值变化事件返回) wx.readBLECharacteristicValue
    • 向特征值写入数据wx.writeBLECharacteristicValue
  8. 断开与蓝牙设备的连接wx.closeBLEConnection
  9. 停用(关闭)蓝牙模块wx.closeBluetoothAdapter

事件监听:

  1. 搜索过程中发现新的蓝牙设备wx.onBluetoothDeviceFound
  2. 蓝牙适配器状态变化wx.onBluetoothAdapterStateChange
  3. 蓝牙设备连接状态变化wx.onBLEConnectionStateChange
  4. 特征值变化(需开启notify)wx.onBLECharacteristicValueChange

其他:

  1. 根据uuid获取已连接的设备wx.getConnectedBluetoothDevices
  2. 获取当前蓝牙模块周期已发现的设备wx.getBluetoothDevices
  3. 获取本机蓝牙适配器的状态wx.getBluetoothAdapterState

踩坑总结

  1. 全局
    • 初始化蓝牙模块后才能调用相关API
    • 初始化之前可执行事件监听,但不会触发事件回调
    • 初始化后,如果errCode=10001,那么其实此时小程序蓝牙模块已经初始化完成,可以调用API,也会有事件回调。
    • iOS 上由于系统需要获取特征值实例,必须要调用获取设备服务和特征值的接口,使用获取到的serviceIdcharacteristicId,才能对特征值进行readwritenotify操作
    • Android 上,部分机型获取设备服务时会多出0000180000001801UUID的服务,这是系统行为,注意不要使用这两个服务
    • Android 上获取到的deviceId为设备 MAC 地址,iOS 上则为设备 UUID
    • iOS 上不同手机搜索到的deviceId是不同的
    • 与蓝牙设备通信的 MTU(最大传输单元)系统限定为20字节,如果超过则会出错,这里应该根据蓝牙设备协议进行分片传输。
    • 特征值的读写是二进制数据,ArrayBuffer类型
  2. 设备连接
    • 必须成对地调用createBLEConnectioncloseBLEConnection接口
    • Android 上,如果连续多次调用createBLEConnection,可能会导致系统持有同一设备多个连接的实例,导致调用 closeBLEConnection 的时候并不能真正地断开与设备的连接
    • 如果未能及时关闭连接释放资源,容易导致state 133 GATT ERROR的异常
    • 若小程序在之前已有搜索过某个蓝牙设备,并成功建立连接,可直接传入之前搜索获取的deviceId直接尝试连接该设备,无需进行搜索操作
    • 蓝牙连接随时可能断开,建议监听wx.onBLEConnectionStateChange回调事件,当蓝牙设备断开时按需执行重连操作
  3. 设备搜索
    • iOS里面蓝牙状态变化以后不能马上开始搜索,否则会搜索不到设备,必须要等待2秒以上
    • Android 上,部分机型无定位权限或者是定位开关未打开时会搜不到设备。原因是蓝牙功能是可以获取到定位的,系统基于安全考量,使用蓝牙接口时必须要有定位权限
    • 设备搜索占用大量资源,要及时关闭
    • wx.getBluetoothDevices获取到的设备列表为蓝牙模块生效期间所有搜索到的蓝牙设备
    • 若在蓝牙模块使用流程结束后未及时调用wx.closeBluetoothAdapter释放资源,那么:
      • 可能不会发现新的设备,因为之前已搜索过
      • 调用wx.getBluetoothDevices时,仍会返回之前的蓝牙使用流程中搜索到的蓝牙设备,即使设备已经不在用户身边,无法连接
    • 蓝牙设备在被搜索到时,系统返回的name字段一般为广播包中的localName字段中的设备名称,而如果与蓝牙设备建立连接,系统返回的name字段会改为从蓝牙设备上获取到的GattName。若需要动态改变设备名称并展示,建议使用localName字段
  4. 向特征值写入数据
    • 并行调用多次可能会导致写入失败
    • 若单次写入数据过长,iOS 上存在系统不会有任何回调的情况(包括错误回调)
    • 特征值必须支持 write
  5. 读取特征值数据
    • 并行调用多次可能会导致读取失败
    • 接口读取到的信息需要在 onBLECharacteristicValueChange 方法注册的回调中获取
    • 特征值必须支持 read
  6. 启用/关闭notify
    • 启用后才会触发特征值变化
    • 监听到的消息要进行过滤处理,有些设备会抽风一样的发送同样的消息,需要在处理逻辑里面去重
    • 开启notify以后并不能马上发送消息,蓝牙设备有个准备的过程,需要延迟1秒以上才能发送,否则会发送失败
    • 特征值必须支持notify或者indicate

原文地址: https://www.jianshu.com/p/ef4a77328b70

赞(0)
未经允许不得转载:49vps官网-vps,模版,cms,编程,福利 » 微信小程序蓝牙开发总结,含踩坑教训
分享到: 更多 (0)

回复 抢沙发