说明
使用 chrome.bluetooth
API 连接到蓝牙设备。所有函数都会通过 chrome.runtime.lastError 报告失败情况。
清单
类型
AdapterState
属性
-
地址
字符串
适配器的地址,格式为“XX:XX:XX:XX:XX:XX”。
-
可用
布尔值
指示适配器是否可用(即是否已启用)。
-
发现
布尔值
指示适配器当前是否正在进行发现。
-
name
字符串
适配器的简明易懂的名称。
-
有源
布尔值
指示适配器是否已通电。
BluetoothFilter
属性
-
filterType
FilterType 可选
要应用于设备列表的过滤条件类型。默认值为全部。
-
限制
number 可选
要返回的蓝牙设备数量上限。如果未指定,则默认值为 0(无限制)。
Device
属性
-
地址
字符串
设备的地址,格式为“XX:XX:XX:XX:XX:XX”。
-
batteryPercentage
number 可选
Chrome 77 及更高版本设备的剩余电量。
-
可连接
布尔值(可选)
Chrome 48 及更高版本指示设备是否可连接。
-
已连接
布尔值(可选)
指示设备当前是否已连接到系统。
-
中转航班
布尔值(可选)
Chrome 48 及更高版本指示设备当前是否正在连接到系统。
-
deviceClass
number 可选
设备的类别,由 http://www.bluetooth.org/en-us/specification/assigned-numbers/baseband 定义的位字段。
-
deviceId
number 可选
-
inquiryRssi
number 可选
Chrome 44 及更高版本接收到的信号强度(以 dBm 为单位)。此字段仅在发现期间可用且有效。在发现之外,其值未指定。
-
inquiryTxPower
number 可选
Chrome 44 及更高版本传输功率电平。此字段仅适用于在 AD 中包含此字段的 LE 设备。它仅在发现期间可用且有效。
-
name
字符串(选填)
设备的简明易懂的名称。
-
已配对
布尔值(可选)
指示设备是否已与系统配对。
-
productId
number 可选
-
transport
交通(可选)
Chrome 76 及更高版本蓝牙设备的传输类型。
-
类型
DeviceType(可选)
设备类型(如果 Chrome 可以识别)。此值从
deviceClass
字段中获取,仅表示可能设备类型中的一小部分。如有疑问,您应直接使用deviceClass
字段。 -
uuids
string[] 可选
设备所宣传的协议、配置文件和服务对应的 UUID。对于经典蓝牙设备,此列表是从 EIR 数据和 SDP 表中获取的。对于低能耗设备,此列表是从 AD 和 GATT 主服务中获取的。对于双模式设备,此信息可能来自两者。
-
vendorId
number 可选
-
vendorIdSource
设备的设备 ID 记录(如有)。
DeviceType
Chrome 识别的常见设备类型。
枚举
“电脑”
“电话”
“调制解调器”
“音频”
"carAudio"
“视频”
“外围设备”
“操纵杆”
“gamepad”
“键盘”
“mouse”
“平板电脑”
"keyboardMouseCombo"
FilterType
用于过滤蓝牙设备的类型。
枚举
“全部”
“已知”
Transport
蓝牙设备的传输类型。
枚举
“无效”
“经典”
“le”
“双重”
VendorIdSource
供应商 ID 的分配机构。
枚举
"bluetooth"
“usb”
方法
getAdapterState()
chrome.bluetooth.getAdapterState(
callback?: function,
): Promise<AdapterState>
获取有关蓝牙适配器的信息。
参数
-
callback
函数 可选
callback
参数如下所示:(adapterInfo: AdapterState) => void
-
adapterInfo
包含适配器信息的对象。
-
返回
-
Promise<AdapterState>
Chrome 91 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
getDevice()
chrome.bluetooth.getDevice(
deviceAddress: string,
callback?: function,
): Promise<Device>
获取有关系统已知的蓝牙设备的信息。
参数
-
deviceAddress
字符串
要获取的设备的地址。
-
callback
函数 可选
callback
参数如下所示:(deviceInfo: Device) => void
-
deviceInfo
包含设备信息的对象。
-
返回
-
Promise<Device>
Chrome 91 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
getDevices()
chrome.bluetooth.getDevices(
filter?: BluetoothFilter,
callback?: function,
): Promise<Device[]>
获取系统已知的蓝牙设备列表,包括已配对的设备和最近发现的设备。
参数
返回
-
Promise<Device[]>
Chrome 91 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
startDiscovery()
chrome.bluetooth.startDiscovery(
callback?: function,
): Promise<void>
开始发现。新发现的设备将通过 onDeviceAdded 事件返回。必须使用 getDevices 获取适配器已知的先前发现的设备,并且只有在这些设备的相关信息发生变化时,才会使用 onDeviceChanged
事件进行更新。
如果此应用已调用 startDiscovery,则发现将无法启动。发现功能可能会消耗大量资源:应尽快调用 stopDiscovery。
参数
-
callback
函数 可选
callback
参数如下所示:() => void
返回
-
Promise<void>
Chrome 91 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
stopDiscovery()
chrome.bluetooth.stopDiscovery(
callback?: function,
): Promise<void>
停止发现。
参数
-
callback
函数 可选
callback
参数如下所示:() => void
返回
-
Promise<void>
Chrome 91 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
事件
onAdapterStateChanged
chrome.bluetooth.onAdapterStateChanged.addListener(
callback: function,
)
当蓝牙适配器的状态发生变化时触发。
参数
-
callback
函数
callback
参数如下所示:(state: AdapterState) => void
onDeviceAdded
chrome.bluetooth.onDeviceAdded.addListener(
callback: function,
)
当有关于新蓝牙设备的信息可用时触发。
onDeviceChanged
chrome.bluetooth.onDeviceChanged.addListener(
callback: function,
)
在已知蓝牙设备的相关信息发生更改时触发。
onDeviceRemoved
chrome.bluetooth.onDeviceRemoved.addListener(
callback: function,
)
在以下情况下触发:之前发现的蓝牙设备超出范围的时间足够长,以至于被视为再次不可用;配对的设备被移除。