基础库版本 >= 3.81.0
支持。
获取在蓝牙模块生效期间所有搜索到的蓝牙设备。包括已经和本机处于连接状态的设备。
参数说明
Object object
属性 | 类型 | 默认值 | 必填 | 说明 | 版本 |
success | function | | 否 | 接口调用成功的回调函数 | 3.81.0 |
fail | function | | 否 | 接口调用失败的回调函数 | 3.81.0 |
complete | function | | 否 | 接⼝调⽤结束的回调函数(调⽤成功、失败都会执⾏) | 3.81.0 |
success参数说明
Object res
属性 | 类型 | 说明 | 版本 |
devices | Array. <Object> | UUID 对应的已连接设备列表 | |
Object devices
属性 | 类型 | 说明 | 版本 |
name | string | 蓝牙设备名称,某些设备可能没有 | |
deviceId | string | 蓝牙设备 id | |
RSSI | number | 当前蓝牙设备的信号强度,单位 dBm | |
advertisData | ArrayBuffer | 当前蓝牙设备的广播数据段中的 ManufacturerData 数据段。 | |
advertisServiceUUIDs | Array. <string> | 当前蓝牙设备的广播数据段中的 ServiceUUIDs 数据段 | |
localName | string | 当前蓝牙设备的广播数据段中的 LocalName 数据段 | |
serviceData | Object | 当前蓝牙设备的广播数据段中的 ServiceData 数据段 | |
connectable | boolean | 当前蓝牙设备是否可连接( Android 8.0 以下不支持返回该值 ) | |
示例代码
function ab2hex(buffer) {
var hexArr = Array.prototype.map.call(
new Uint8Array(buffer),
function(bit) {
return ('00' + bit.toString(16)).slice(-2)
}
)
return hexArr.join('');
}
bl.getBluetoothDevices({
success: function (res) {
console.log(res)
if (res.devices[0]) {
console.log(ab2hex(res.devices[0].advertisData))
}
}
})
注意
- 该接口获取到的设备列表为蓝牙模块生效期间所有搜索到的蓝牙设备,若在蓝牙模块使用流程结束后未及时调用 bl.closeBluetoothAdapter 释放资源,会存在调用该接口会返回之前的蓝牙使用流程中搜索到的蓝牙设备,可能设备已经不在用户身边,无法连接。
错误异常
错误码 | 错误信息 | 场景 |
0 | ok | 正常 |
-1 | already connect | 已连接 |
10000 | not init | 未初始化蓝牙适配器 |
10001 | not available | 当前蓝牙适配器不可用 |
10002 | no device | 没有找到指定设备 |
10003 | connection fail | 连接失败 |
10004 | no service | 没有找到指定服务 |
10005 | no characteristic | 没有找到指定特征 |
10006 | no connection | 当前连接已断开 |
10007 | property not support | 当前特征不支持此操作 |
10008 | system error | 其余所有系统上报的异常 |
10009 | system not support | Android 系统特有,系统版本低于 4.3 不支持 BLE |
10012 | operate time out | 连接超时 |
10013 | invalid_data | 连接 deviceId 为空或者是格式不正确 |
10014 | invalid param | 参数不正确 |