背景
使用微信小程序兼容Android、Ios双平台上线与蓝牙硬件的交互。具体实现文章结尾会放上源码。 
1、蓝牙定位
在使用扫描前一定要先查看蓝牙和定位是否全部开启,否则就会导致没有反应。
2、UUID
Android和Ios有所不同,Android使用小写,Ios使用大写。可以使用toLowerCase()方法转换。
3、订阅 notifyBLECharacteristicValueChange
有些同学可能遇到Ios没有问题,特征值返回全部正常,但是到了Android上怎么也无法正常显示,这是因为Android notifyBLECharacteristicValueChange方法默认使用的不是notification,需要代码指定,这一点在官方api中并没有提现出来,要着重注意。
wx.notifyBLECharacteristicValueChange({
deviceId,
serviceId:serviceId,
type: 'notification',
characteristicId: uuid.toLowerCase(),
state: true,
success(res) {
console.log('订阅成功', res.errMsg)
wx.readBLECharacteristicValue({
deviceId,
serviceId:serviceId,
})
},
fail(res) {
console.log("订阅失败", res.errMsg)
}
})
4、MTU
在实现过程中,发现一个特别诡异的问题,就是在Android设备上返回特征值比较长的时候就无法返回,Ios没有这个问题,在查阅大量资料以后发现罪魁祸首就是MTU。MTU蓝牙最大传输单元,Ios中不用设置,Android却需要。
wx.setBLEMTU(Object object) 基础库 2.11.0 开始支持,低版本需做兼容处理。 以 Promise 风格 调用:支持 小程序插件:支持,需要小程序基础库版本不低于 2.11.0 设置蓝牙最大传输单元。需在 wx.createBLEConnection调用成功后调用,mtu 设置范围 (22,512)。安卓5.1以上有效。 参数 Object object 属性 类型 默认值 必填 说明 deviceId string 是 用于区分设备的 id mtu number 是 最大传输单元(22,512) 区间内,单位 bytes success function 否 接口调用成功的回调函数 fail function 否 接口调用失败的回调函数 complete function 否 接口调用结束的回调函数(调用成功、失败都会执行)
wx.setBLEMTU({
deviceId: deviceId,
mtu:512,
success:(res)=>{
console.log("setBLEMTU success>>", res)
},
fail:(res)=>{
console.log("setBLEMTU fail>>", res)
}
}),
后续发现问题还会追加!
资源:微信小程序蓝牙实现-兼容Android和Ios
|