ble-低功耗蓝牙相关功能
ble
模块用于提供BLE GATT Server (从机)与 Client (主机)功能,基于BLE 4.2协议。
示例:
见github:https://github.com/QuecPython/example_BLE
当前仅EC200U/EC600U/EG915U/EG912U/FCM360W型号支持
ble
功能。
初始化相关功能
ble.gattStart
ble.gattStart()
开启 BLE GATT 功能。
返回值描述:
- 执行成功返回整型0,失败返回整型-1。
ble.gattStop
ble.gattStop()
关闭 BLE GATT 功能。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.getStatus
ble.getStatus()
获取 BLE 的状态。
返回值描述:
0 - BLE处于停止状态。1 - BLE处于开启状态。-1 - 获取状态失败。
ble.getPublicAddr
ble.getPublicAddr()
获取 BLE 协议栈正在使用的公共地址。该接口需要在BLE已经初始化完成并启动成功后才能调用,比如在回调中收到 event_id 为0的事件之后,即 start 成功后,去调用。
返回值描述:
执行成功返回bytearray类型的BLE地址,大小6个byte,失败返回整型-1。
示例:
>>> addr = ble.getPublicAddr()
>>> print(addr)
b'\xdb3\xf5\x1ek\xac'
>>> mac = '{:02x}:{:02x}:{:02x}:{:02x}:{:02x}:{:02x}'.format(addr[5], addr[4], addr[3], addr[2], addr[1], addr[0])
>>> print('mac = [{}]'.format(mac))
mac = [ac:6b:1e:f5:33:db]
如果有出厂设置默认蓝牙MAC地址,那么该接口获取的MAC地址和默认的蓝牙MAC地址是一致的;如果没有设置,那么该接口获取的地址,将是蓝牙启动后随机生成的静态地址,因此在每次重新上电运行蓝牙功能时都不相同。
BLE Server相关功能
ble.serverInit
ble.serverInit(user_cb)
初始化 BLE Server 并注册回调函数。
参数描述:
user_cb
-回调函数,类型为function。回调函数参数含义:args[0] 固定表示event_id,args[1]固定 表示状态,0表示成功,非0表示失败。回调函数的参数个数并不是固定2个,而是根据第一个参数args[0]来决定的,下表中列出了不同事件ID对应的参数个数及说明。
event_id | 参数个数 | 参数说明 |
---|---|---|
0 | 2 | args[0] :event_id,表示 BT/BLE start args[1] :status,表示操作的状态,0-成功,非0-失败 |
1 | 2 | args[0] :event_id,表示 BT/BLE stop args[1] :status,表示操作的状态,0-成功,非0-失败 |
16 | 4 | args[0] :event_id,表示 BLE connect args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id args[3] :addr,BT/BLE address,bytearray类型数据 |
17 | 4 | args[0] :event_id,表示 BLE disconnect args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id, args[3] :addr,BT/BLE address,bytearray类型数据 |
18 | 7 | args[0] :event_id,表示 BLE update connection parameter args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id args[3] :max_interval,最大的间隔,间隔:1.25ms,取值范围:6-3200,时间范围:7.5ms\ ~ 4s args[4] :min_interval,最小的间隔,间隔:1.25ms,取值范围:6-3200,时间范围:7.5ms\ ~ 4s args[5] :latency,从机忽略连接状态事件的时间。需满足:(1+latecy)*max_interval*2*1.25<timeout*10 args[6] :timeout,没有交互,超时断开时间,间隔:10ms,取值范围:10-3200ms,时间范围:100ms ~ 32s |
20 | 4 | args[0] :event_id,表示 BLE connection mtu args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :handle args[3] :mtu值 |
21 | 7 | args[0] :event_id,表示 client写入特征值或描述符通知 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,获取数据的长度 args[3] :data,一个数组,存放获取的数据 args[4] :attr_handle,属性句柄,整型值 args[5] :short_uuid,整型值 args[6] :long_uuid,一个16字节数组,存放长UUID |
22 | 7 | args[0] :event_id,表示client读取特征值或描述符通知 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,获取数据的长度 args[3] :data,一个数组,存放获取的数据 args[4] :attr_handle,属性句柄,整型值 args[5] :short_uuid,整型值 args[6] :long_uuid,一个16字节数组,存放长UUID |
25 | 2 | args[0] :event_id,表示 server发送通知并接收到了发送结束通知 args[1] :status,表示操作的状态,0-成功,非0-失败 |
63 | 2 | args[0] :event_id,表示SMP配对流程完成通知 args[1] :status,表示操作的状态,0-成功,非0-失败 |
64 | 5 | args[0] :event_id,表示SMP配对用户确认通知 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id args[3] :pair_mode,配对模式,整型值。 0 - 配对失败 1 - Legacy Pairing:使用Just Works,不需要输入PIN码 2 - Legacy Pairing:使用Passkey Entry,显示PIN码,不需要输入PIN码 3 - Legacy Pairing:使用Passkey Entry,需要输入PIN码 4 - Legacy Pairing:使用OOB,目前不支持这种方式 5 - Secure Connections Pairing:使用Just Works,不需要输入PIN码 6 - Secure Connections Pairing:使用Numeric Comparison,显示PIN码,不需要输入PIN码 7 - Secure Connections Pairing:使用Passkey Entry,显示PIN码,不需要输入PIN码 8 - Secure Connections Pairing:使用Passkey Entry,需要输入PIN码 9 - Secure Connections Pairing:使用OOB,目前不支持这种方式 args[4] :pin_code,PIN码,整型值 |
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_callback(args):
event_id = args[0]
status = args[1]
print('[ble_callback]: event_id={}, status={}'.format(event_id, status))
if event_id == 0: # ble start
if status == 0:
print('[callback] BLE start success.')
else:
print('[callback] BLE start failed.')
elif event_id == 1: # ble stop
if status == 0:
print('[callback] ble stop successful.')
else:
print('[callback] ble stop failed.')
elif event_id == 16: # ble connect
if status == 0:
print('[callback] ble connect successful.')
connect_id = args[2]
addr = args[3] # 这是一个bytearray类型
addr_str = '{:02x}:{:02x}:{:02x}:{:02x}:{:02x}:{:02x}'.format(addr[0], addr[1], addr[2], addr[3], addr[4], addr[5])
print('[callback] connect_id = {}, addr = {}'.format(connect_id, addr_str))
else:
print('[callback] ble connect failed.')
elif event_id == 17: # ble disconnect
if status == 0:
print('[callback] ble disconnect successful.')
connect_id = args[2]
addr = args[3] # 这是一个bytearray类型
addr_str = '{:02x}:{:02x}:{:02x}:{:02x}:{:02x}:{:02x}'.format(addr[0], addr[1], addr[2], addr[3], addr[4], addr[5])
print('[callback] connect_id = {}, addr = {}'.format(connect_id, addr_str))
else:
print('[callback] ble disconnect failed.')
ble.gattStop()
return
elif event_id == 18: # ble update connection parameter
if status == 0:
print('[callback] ble update parameter successful.')
connect_id = args[2]
max_interval = args[3]
min_interval = args[4]
latency = args[5]
timeout = args[6]
print('[callback] connect_id={},max_interval={},min_interval={},latency={},timeout={}'.format(connect_id, max_interval, min_interval, latency, timeout))
else:
print('[callback] ble update parameter failed.')
ble.gattStop()
return
elif event_id == 20: # ble connection mtu
if status == 0:
print('[callback] ble connect mtu successful.')
handle = args[2]
ble_mtu = args[3]
print('[callback] handle = {:#06x}, ble_mtu = {}'.format(handle, ble_mtu))
else:
print('[callback] ble connect mtu failed.')
ble.gattStop()
return
elif event_id == 21: # server:when ble client write characteristic value or descriptor,server get the notice
if status == 0:
print('[callback] ble recv successful.')
data_len = args[2]
data = args[3] # 这是一个bytearray类型
attr_handle = args[4]
short_uuid = args[5]
long_uuid = args[6] # 这是一个bytearray类型
print('len={}, data:{}'.format(data_len, data))
print('attr_handle = {:#06x}'.format(attr_handle))
print('short uuid = {:#06x}'.format(short_uuid))
print('long uuid = {}'.format(long_uuid))
else:
print('[callback] ble recv failed.')
ble.gattStop()
return
elif event_id == 22: # server:when ble client read characteristic value or descriptor,server get the notice
if status == 0:
print('[callback] ble recv read successful.')
data_len = args[2]
data = args[3] # 这是一个bytearray类型
attr_handle = args[4]
short_uuid = args[5]
long_uuid = args[6] # 这是一个bytearray类型
print('len={}, data:{}'.format(data_len, data))
print('attr_handle = {:#06x}'.format(attr_handle))
print('short uuid = {:#06x}'.format(short_uuid))
print('long uuid = {}'.format(long_uuid))
else:
print('[callback] ble recv read failed.')
ble.gattStop()
return
elif event_id == 25: # server send notification,and recieve send end notice
if status == 0:
print('[callback] ble send data successful.')
else:
print('[callback] ble send data failed.')
else:
print('unknown event id.')
ble.serverInit(ble_callback)
ble.serverRelease
ble.serverRelease()
BLE Server 资源释放。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.setLocalName
ble.setLocalName(code, name)
设置 BLE 名称。
参数描述:
code
-编码模式,类型为整型。0 - UTF8,1 - GBK。name
-编码模式,类型为string。BLE 名称,名称最长不能超过29个字节。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
>>> ble.setLocalName(0, 'QuecPython-BLE')
0
对于BLE,设备在广播时,如果希望手机扫描app扫描时,能看到广播设备的名称,是需要在广播数据中包含蓝牙名称的,或者在扫描回复数据中包含设备名称。
ble.setAdvParam
ble.setAdvParam(min_adv,max_adv,adv_type,addr_type,channel,filter_policy,discov_mode,no_br_edr,enable_adv)
设置广播参数。
参数描述:
min_adv
-最小广播间隔,范围0x0020-0x4000。计算方式:时间间隔 = min_adv * 0.625,单位ms。类型为整型。max_adv
-最大广播间隔,范围0x0020-0x4000。计算方式:时间间隔 = max_adv * 0.625,单位ms。类型为整型。adv_type
-广播类型,0 - 可连接的非定向广播,默认选择,1 - 可连接高占空比的定向广播,2 - 可扫描的非定向广播,3 - 不可连接的非定向广播,4 - 可连接低占空比的定向广播。类型为整型。addr_type
-本地地址类型,0 - 公共地址,1 - 随机地址。类型为整型。channel
-广播通道,1 - 37信道,2 - 38信道,4 - 39信道,7 - 上述3个通道都选择,默认该选项。类型为整型。filter_policy
-广播过滤策略,0 - 处理所有设备的扫描和连接请求,1 - 处理所有设备的连接请求和只处理白名单设备的扫描请求(暂不支持),2 - 处理所有设备的扫描请求和只处理白名单设备的连接请求(暂不支持),3 - 只处理白名单设备的连接和扫描请求(暂不支持)。类型为整型。discov_mode
-发现模式,GAP协议使用,1 - 有限可发现模式,2 - 一般可发现模式。类型为整型。no_br_edr
-不用BR/EDR,1-不用BR/EDR,默认为该值,0-使用BR/EDR。类型为整型。enable_adv
-使能广播,1-使能,默认为该值,0-不使能。类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_gatt_set_param():
min_adv = 0x300
max_adv = 0x320
adv_type = 0 # 可连接的非定向广播,默认选择
addr_type = 0 # 公共地址
channel = 0x07
filter_strategy = 0 # 处理所有设备的扫描和连接请求
discov_mode = 2
no_br_edr = 1
enable_adv = 1
ret = ble.setAdvParam(min_adv, max_adv, adv_type, addr_type, channel, filter_strategy, discov_mode, no_br_edr, enable_adv)
if ret != 0:
print('ble_gatt_set_param failed.')
return -1
print('ble_gatt_set_param success.')
return 0
ble.setAdvData
ble.setAdvData(data)
设置广播数据内容。
参数描述:
data
-广播数据,最长不超过31个字节,类型为bytearray。广播数据的内容,采用 length+type+data 的格式。一条广播数据中可以包含多个这种格式数据的组合,如下示例中包含了两个数据组合,第一个是 "0x02, 0x01, 0x05",0x02表示后面有两个数据,分别是0x01和0x05,0x01即type,0x05表示具体数据;第二个是ble名称数据组合, length为ble名称长度加1、type为0x09,具体数据为name对应的具体编码值。关于type具体值代表的含义,请参考蓝牙协议官方标准文档。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_gatt_set_data():
adv_data = [0x02, 0x01, 0x05]
ble_name = "Quectel_ble"
length = len(ble_name) + 1
adv_data.append(length)
adv_data.append(0x09)
name_encode = ble_name.encode('UTF-8')
for i in range(0, len(name_encode)):
adv_data.append(name_encode[i])
print('set adv_data:{}'.format(adv_data))
data = bytearray(adv_data)
ret = ble.setAdvData(data)
if ret != 0:
print('ble_gatt_set_data failed.')
return -1
print('ble_gatt_set_data success.')
return 0
ble.setAdvRspData
ble.setAdvRspData(data)
设置扫描回复数据。
参数描述:
data
-扫描回复数据,最长不超过31个字节,类型为bytearray。 格式和上面设置广播数据内容接口一致。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_gatt_set_rsp_data():
adv_data = []
ble_name = "Quectel_ble"
length = len(ble_name) + 1
adv_data.append(length)
adv_data.append(0x09)
name_encode = ble_name.encode('UTF-8')
for i in range(0, len(name_encode)):
adv_data.append(name_encode[i])
print('set adv_rsp_data:{}'.format(adv_data))
data = bytearray(adv_data)
ret = ble.setAdvRspData(data)
if ret != 0:
print('ble_gatt_set_rsp_data failed.')
return -1
print('ble_gatt_set_rsp_data success.')
return 0
当client设备扫描方式为积极扫描时,设置扫描回复数据才有意义。
ble.addService
ble.addService(primary, server_id, uuid_type, uuid_s, uuid_l)
增加一个服务。
参数描述:
primary
-服务类型,1表示主要服务,其他值表示次要服务,类型为整型。server_id
-服务ID,用来确定某一个服务,类型为整型。uuid_type
-uuid类型,0 - 长UUID,128bit;1 - 短UUID,16bit。类型为整型。uuid_s
-短UUID,2个字节(16bit),类型为整型,当uuid_type为0时,该值给0。uuid_l
-长UUID,16个字节(128bit),类型为bytearray,当uuid_type为1时,该值填 bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_gatt_add_service():
primary = 1
server_id = 0x01
uuid_type = 1 # 短UUID
uuid_s = 0x180F
uuid_l = bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])
ret = ble.addService(primary, server_id, uuid_type, uuid_s, uuid_l)
if ret != 0:
print('ble_gatt_add_service failed.')
return -1
print('ble_gatt_add_service success.')
return 0
ble.addChara
ble.addChara(server_id, chara_id, chara_prop, uuid_type, uuid_s, uuid_l)
在服务里增加一个特征。
参数描述:
server_id
-服务ID,用来确定某一个服务,类型为整型。chara_id
-特征ID,类型为整型。chara_prop
-特征的属性,十六进制数,可通过“或运算”同时指定多个属性,值具体含义如下表,类型为整型。
值 | 含义 |
---|---|
0x01 | 广播 |
0x02 | 可读 |
0x04 | 0x04 - 可写且不需要链路层应答 |
0x08 | 可写 |
0x10 | 通知 |
0x20 | 指示 |
0x40 | 认证签名写 |
0x80 | 扩展属性 |
uuid_type
-uuid类型,0 - 长UUID,128bit;1 - 短UUID,16bit。类型为整型。uuid_s
-短UUID,2个字节(16bit),类型为整型,当uuid_type为0时,该值给0。uuid_l
-长UUID,16个字节(128bit),类型为bytearray,当uuid_type为1时,该值填 bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_gatt_add_characteristic():
server_id = 0x01
chara_id = 0x01
chara_prop = 0x02 | 0x10 | 0x20 # 0x02-可读 0x10-通知 0x20-指示
uuid_type = 1 # 短UUID
uuid_s = 0x2A19
uuid_l = bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])
ret = ble.addChara(server_id, chara_id, chara_prop, uuid_type, uuid_s, uuid_l)
if ret != 0:
print('ble_gatt_add_characteristic failed.')
return -1
print('ble_gatt_add_characteristic success.')
return 0
ble.addCharaValue
ble.addCharaValue(server_id, chara_id, permission, uuid_type, uuid_s, uuid_l, value)
在特征里增加一个特征值。
参数描述:
server_id
-服务ID,用来确定某一个服务,类型为整型。chara_id
-特征ID,类型为整型。permission
-特征值的权限,2个字节,十六进制数,可通过“或运算”同时指定多个属性,值具体含义如下表,类型为整型。
值 | 含义 |
---|---|
0x0001 | 可读权限 |
0x0002 | 可写权限 |
0x0004 | 读需要认证 |
0x0008 | 读需要授权 |
0x0010 | 读需要加密 |
0x0020 | 读需要授权认证 |
0x0040 | 写需要认证 |
0x0080 | 写需要授权 |
0x0100 | 写需要加密 |
0x0200 | 写需要授权认证 |
uuid_type
-uuid类型,0 - 长UUID,128bit;1 - 短UUID,16bit。类型为整型。uuid_s
-短UUID,2个字节(16bit),类型为整型,当uuid_type为0时,该值给0。uuid_l
-长UUID,16个字节(128bit),类型为bytearray,当uuid_type为1时,该值填 bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])。value
-特征值数据。类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_gatt_add_characteristic_value():
data = []
server_id = 0x01
chara_id = 0x01
permission = 0x0001 | 0x0002
uuid_type = 1 # 短UUID
uuid_s = 0x2A19
uuid_l = bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])
for i in range(0, 244):
data.append(0x00)
value = bytearray(data)
ret = ble.addCharaValue(server_id, chara_id, permission, uuid_type, uuid_s, uuid_l, value)
if ret != 0:
print('ble_gatt_add_characteristic_value failed.')
return -1
print('ble_gatt_add_characteristic_value success.')
return 0
ble.changeCharaValue
ble.changeCharaValue(server_id, chara_id, value)
修改特征值。
参数描述:
server_id
-服务ID,用来确定某一个服务,类型为整型。chara_id
-特征ID,类型为整型。value
-特征值数据。类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.addCharaDesc
ble.addCharaDesc(server_id, chara_id, permission, uuid_type, uuid_s, uuid_l, value)
在特征里增加一个特征描述,注意特征描述和特征值同属与一个特征。
参数描述:
server_id
-服务ID,用来确定某一个服务,类型为整型。chara_id
-特征ID,类型为整型。permission
-特征值的权限,2个字节,十六进制数,可通过“或运算”同时指定多个属性,值具体含义如下表,类型为整型。
值 | 含义 |
---|---|
0x0001 | 可读权限 |
0x0002 | 可写权限 |
0x0004 | 读需要认证 |
0x0008 | 读需要授权 |
0x0010 | 读需要加密 |
0x0020 | 读需要授权认证 |
0x0040 | 写需要认证 |
0x0080 | 写需要授权 |
0x0100 | 写需要加密 |
0x0200 | 写需要授权认证 |
uuid_type
-uuid类型,0 - 长UUID,128bit;1 - 短UUID,16bit。类型为整型。uuid_s
-短UUID,2个字节(16bit),类型为整型,当uuid_type为0时,该值给0。uuid_l
-长UUID,16个字节(128bit),类型为bytearray,当uuid_type为1时,该值填 bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])。value
-特征描述数据。类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
示例:
def ble_gatt_add_characteristic_desc():
data = [0x00, 0x00]
server_id = 0x01
chara_id = 0x01
permission = 0x0001 | 0x0002
uuid_type = 1 # 短UUID
uuid_s = 0x2902
uuid_l = bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])
value = bytearray(data)
ret = ble.addCharaDesc(server_id, chara_id, permission, uuid_type, uuid_s, uuid_l, value)
if ret != 0:
print('ble_gatt_add_characteristic_desc failed.')
return -1
print('ble_gatt_add_characteristic_desc success.')
return 0
ble.addOrClearService
ble.addOrClearService(option, mode)
增加已添加的所有服务信息到模块,或者删除模块中已增加的所有服务信息。
参数描述:
option
-操作类型,类型为整型。0 - 删除服务,1 - 增加服务。mode
-是否保留系统默认服务,类型为整型。 0 - 删除系统默认的GAP和GATT服务,1 - 保留系统默认的GAP和GATT服务。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.sendNotification
ble.sendNotification(connect_id, attr_handle, value)
发送通知。
参数描述:
connect_id
-连接ID,类型为整型。attr_handle
-属性句柄,类型为整型。value
-要发送的数据,发送数据长度不要超过MTU,类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.sendIndication
ble.sendIndication(connect_id, attr_handle, value)
发送指示。
参数描述:
connect_id
-连接ID,类型为整型。attr_handle
-属性句柄,类型为整型。value
-要发送的数据,发送数据长度不要超过MTU,类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.advStart
ble.advStart()
开启广播。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.advStop
ble.advStop()
停止广播。
返回值描述:
执行成功返回整型0,失败返回整型-1。
BLE Client相关功能
ble.clientInit
ble.clientInit(user_cb)
初始化 BLE Client 并注册回调函数。
参数描述:
user_cb
-回调函数,类型为function。回调函数参数含义:args[0] 固定表示event_id,args[1] 固定表示状态,0表示成功,非0表示失败。回调函数的参数个数并不是固定2个,而是根据第一个参数args[0]来决定的,下表中列出了不同事件ID对应的参数个数及说明。
event_id | 参数个数 | 参数说明 |
---|---|---|
0 | 2 | args[0] :event_id,表示 BT/BLE start args[1] :status,表示操作的状态,0-成功,非0-失败 |
1 | 2 | args[0] :event_id,表示 BT/BLE stop args[1] :status,表示操作的状态,0-成功,非0-失败 |
16 | 4 | args[0] :event_id,表示 BLE connect args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id args[3] :addr,BT/BLE address,bytearray类型数据 |
17 | 4 | args[0] :event_id,表示 BLE disconnect args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id, args[3] :addr,BT/BLE address,bytearray类型数据 |
18 | 7 | args[0] :event_id,表示 BLE update connection parameter args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id args[3] :max_interval,最大的间隔,间隔:1.25ms,取值范围:6-3200,时间范围:7.5ms ~ 4s args[4] :min_interval,最小的间隔,间隔:1.25ms,取值范围:6-3200,时间范围:7.5ms ~ 4s args[5] :latency,从机忽略连接状态事件的时间。需满足:(1+latecy)*max_interval*2*1.25<timeout*10 args[6] :timeout,没有交互,超时断开时间,间隔:10ms,取值范围:10-3200,时间范围:100ms ~ 32s |
19 | 9 | args[0] :event_id,表示 BLE scan report args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :event_type args[3] :扫描到的设备名称 args[4] :设备地址类型 args[5] :设备地址,bytearray类型数据 args[6] :rssi,信号强度 args[7] :data_len,扫描的原始数据长度 args[8] :data,扫描的原始数据 |
20 | 4 | args[0] :event_id,表示 BLE connection mtu args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :handle args[3] :mtu值 |
23 | 4 | args[0] :event_id,表示 client接收到通知 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,包含句柄等数据的原始数据,数据格式及解析见最后的综合示例程序 |
24 | 4 | args[0] :event_id,表示 client recieve indication,即接收指示 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,包含indication的原始数据,数据格式及解析见最后的综合示例程序 |
26 | 2 | args[0] :event_id,表示 开始查找服务 args[1] :status,表示操作的状态,0-成功,非0-失败 |
27 | 5 | args[0] :event_id,表示查找到服务 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :start_handle,表示service的开始句柄 args[3] :end_handle,表示service的结束句柄 args[4] :UUID,表示service的UUID(短UUID) |
28 | 4 | args[0] :event_id,表示查找到服务特征 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,包含句柄、属性、UUID等数据的原始数据,数据格式及解析见最后的综合示例程序 |
29 | 4 | args[0] :event_id,表示 查找到特征描述 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,包含句柄、UUID等数据的原始数据,数据格式及解析见最后的综合示例程序 |
30 | 2 | args[0] :event_id,表示写入特征值并需要server端确认 args[1] :status,表示操作的状态,0-成功,非0-失败 |
31 | 2 | args[0] :event_id,表示写入特征值,无需server端确认 args[1] :status,表示操作的状态,0-成功,非0-失败 |
32 | 4 | args[0] :event_id,表示通过句柄来读取特征值 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,原始数据 |
33 | 4 | args[0] :event_id,表示通过UUID来读取特征值 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,原始数据 |
34 | 4 | args[0] :event_id,表示读取多个特征值 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,原始数据 |
35 | 2 | args[0] :event_id,表示 写入特征描述,需server端确认 args[1] :status,表示操作的状态,0-成功,非0-失败 |
36 | 4 | args[0] :event_id,表示读特征描述 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :data_len,数据长度 args[3] :data,原始数据 |
37 | 3 | args[0] :event_id,表示属性错误 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :errcode,错误码 |
63 | 2 | args[0] :event_id,表示SMP配对流程完成通知 args[1] :status,表示操作的状态,0-成功,非0-失败 |
64 | 5 | args[0] :event_id,表示SMP配对用户确认通知 args[1] :status,表示操作的状态,0-成功,非0-失败 args[2] :connect_id args[3] :pair_mode,配对模式,整型值。 0 - 配对失败 1 - Legacy Pairing:使用Just Works,不需要输入PIN码 2 - Legacy Pairing:使用Passkey Entry,显示PIN码,不需要输入PIN码 3 - Legacy Pairing:使用Passkey Entry,需要输入PIN码 4 - Legacy Pairing:使用OOB,目前不支持这种方式 5 - Secure Connections Pairing:使用Just Works,不需要输入PIN码 6 - Secure Connections Pairing:使用Numeric Comparison,显示PIN码,不需要输入PIN码 7 - Secure Connections Pairing:使用Passkey Entry,显示PIN码,不需要输入PIN码 8 - Secure Connections Pairing:使用Passkey Entry,需要输入PIN码 9 - Secure Connections Pairing:使用OOB,目前不支持这种方式 args[4] :pin_code,PIN码,整型值 |
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.clientRelease
ble.clientRelease()
BLE Client 资源释放。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.setScanParam
ble.setScanParam(scan_mode, interval, scan_window, filter_policy, addr_type)
设置扫描参数。
参数描述:
scan_mode
-扫描模式,类型为整型。扫描模式,默认为积极扫描。0 - 消极扫描,1 - 积极扫描。interval
-扫描间隔,类型为整型。范围0x0004-0x4000,时间间隔 = interval * 0.625,单位ms。scan_window
-一次扫描的时间,类型为整型。范围0x0004-0x4000,扫描时间 = scan_window* 0.625,单位ms。filter_policy
-扫描过滤策略,类型为整型。默认为0。0 - 过滤目标地址不是本设备的定向广播包,1 - 过滤目标地址不是本设备的定向广播包及白名单之外的广播包,2 -过滤目标地址不是本设备且没使用Resolvable private address的定向广播包,3 - 过滤目标地址不是本设备且没使用Resolvable private address的定向广播包及白名单之外的广播包。addr_type
-本地地址类型,类型为整型。0 - 公共地址,1 - 随机地址。
返回值描述:
执行成功返回整型0,失败返回整型-1。
扫描时间
scan_window
不能大于扫描间隔interval
。如果两者相等,则表示连续不停的扫描。此时 BLE 的 Controller 会连续运行扫描,占满系统资源而导致无法执行其他任务。所以不允许设置连续扫描。并且不建议将时间设置的太短,扫描越频繁则功耗越高。
ble.scanStart
ble.scanStart()
开始扫描。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.scanStop
ble.scanStop()
停止扫描。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.setScanFilter
ble.setScanFilter(act)
打开或者关闭扫描过滤。如果打开,那么扫描设备的广播数据时,同一个设备的广播数据只会上报一次;如果关闭,则同一个设备的所有的广播数据都会上报。
参数描述:
act
-扫描过滤开关,类型为整型。0 - 关闭扫描过滤功能,1 - 打开扫描过滤功能。默认打开过滤功能。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.connect
ble.connect(addr_type, addr)
根据指定的设备地址去连接设备。
参数描述:
addr_type
-地址类型,类型为整型。0 - 公共地址,1 - 随机地址。addr
-BLE地址,类型为bytearray,大小为6字节。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.cancelConnect
ble.cancelConnect(addr)
取消正在建立的连接。
参数描述:
addr
-BLE地址,类型为bytearray,大小为6字节。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.disconnect
ble.disconnect(connect_id)
断开已建立的连接。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.discoverAllService
ble.discoverAllService(connect_id)
扫描所有的服务。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.discoverByUUID
ble.discoverByUUID(connect_id, uuid_type, uuid_s, uuid_l)
扫描指定UUID的服务。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。uuid_type
-uuid类型,0 - 长UUID,128bit;1 - 短UUID,16bit。类型为整型。uuid_s
-短UUID,2个字节(16bit),类型为整型,当uuid_type为0时,该值给0。uuid_l
-长UUID,16个字节(128bit),类型为bytearray,当uuid_type为1时,该值填 bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.discoverAllIncludes
ble.discoverAllIncludes(connect_id, start_handle, end_handle)
扫描所有的引用,start_handle和end_handle要属于同一个服务。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。start_handle
-开始句柄,从这个句柄开始寻找引用,类型为整型。end_handle
-结束句柄,从这个句柄结束寻找引用,类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.discoverAllChara
ble.discoverAllChara(connect_id, start_handle, end_handle)
扫描所有的特征,start_handle和end_handle要属于同一个服务。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。start_handle
-开始句柄,从这个句柄开始寻找特征,类型为整型。end_handle
-结束句柄,从这个句柄结束寻找特征,类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.discoverAllCharaDesc
ble.discoverAllCharaDesc(connect_id, start_handle, end_handle)
扫描所有特征的描述,start_handle和end_handle要属于同一个服务。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。start_handle
-开始句柄,从这个句柄开始寻找特征描述,类型为整型。end_handle
-结束句柄,从这个句柄结束寻找特征描述,类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.readCharaByUUID
ble.readCharaByUUID(connect_id, start_handle, end_handle, uuid_type, uuid_s, uuid_l)
读取指定UUID的特征值,start_handle和end_handle必须要包含一个特征值句柄。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。start_handle
-开始句柄,一定要属于同一个服务的句柄,类型为整型。end_handle
-结束句柄,一定要属于同一个服务的句柄,类型为整型。uuid_type
-uuid类型,0 - 长UUID,128bit;1 - 短UUID,16bit。类型为整型。uuid_s
-短UUID,2个字节(16bit),类型为整型,当uuid_type为0时,该值给0。uuid_l
-长UUID,16个字节(128bit),类型为bytearray,当uuid_type为1时,该值填 bytearray([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00])。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.readCharaByHandle
ble.readCharaByHandle(connect_id, handle, offset, is_long)
读取指定句柄的特征值。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。handle
-特征值句柄,类型为整型。offset
-偏移位置,类型为整型。is_long
-长特征值标志,0-短特征值,一次可以读取完;1-长特征值,分多次读取。类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.readCharaDesc
ble.readCharaDesc(connect_id, handle, is_long)
读取特征描述。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。handle
-特征值句柄,类型为整型。is_long
-长特征值标志,0-短特征值,一次可以读取完;1-长特征值,分多次读取。类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.writeChara
ble.writeChara(connect_id, handle, offset, is_long, data)
写入特征值,需要对端应答。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。handle
-特征值句柄,类型为整型。offset
-偏移位置,类型为整型。is_long
-长特征值标志,0-短特征值,一次可以读取完;1-长特征值,分多次读取。类型为整型。data
-特征值数据,类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.writeCharaNoRsp
ble.writeCharaNoRsp(connect_id, handle, data)
写入特征值,不需要对端应答。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。handle
-特征值句柄,类型为整型。data
-特征值数据,类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.writeCharaDesc
ble.writeCharaDesc(connect_id, handle, data)
写入特征描述。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。handle
-特征描述句柄,类型为整型。data
-特征描述数据,类型为bytearray。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.exchangeMtu
ble.exchangeMtu(connect_id, mtu_size)
发送MTU交换请求。MTU交换请求应该由client端发起。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。mtu_size
-MTU大小。
返回值描述:
执行成功返回整型0,失败返回整型-1。
BLE SMP相关功能
ble.smpSetConfig
ble.smpSetConfig(io_cap, auth_req, passkey, timeout)
配对能力配置。
参数描述:
io_cap
-设备输入输出能力,类型为整型,默认为3。
值 | 含义 |
---|---|
0 | 只有显示能力,可以显示PIN码 |
1 | 只有显示能力,只能显示Yes/No,不能显示PIN码 |
2 | 只有输入能力,可以输入PIN码 |
3 | 没有输入输出能力 |
4 | 有输入输出能力,既可以显示PIN码,又可以输入PIN码。 |
auth_req
-认证请求参数,类型为整型,默认为9。
Bit0 | Bit1 | Bit2 | Bit3 | |
---|---|---|---|---|
0 | 配对后不绑定 | 预留,无实际含义 | 不启用MITM | 使用Legacy Pairing |
1 | 配对后绑定 | 预留,无实际含义 | 启用MITM | 使用Secure Connections Pairing |
passkey
-配对显示的PIN码,类型为整型,默认为123456。timeout
-配对超时时间,单位为100ms,类型为整型,默认为160。
返回值描述:
执行成功返回整型0,失败返回整型-1。
配对方法选择过程:
BLE smp配对有Legacy Pairing
和Secure Connections Pairing
两种模式,具体有如下4种配对方法:
OOB
Just Works
Passkey Entry
Numeric Comparison (只有 Secure Connections Pairing 模式才有)
具体选择哪一种方法配对,是由配对的双方在交换各自的IO能力后协商决定的,基本分为下面几个阶段:
阶段1:配对双方会先确认使用Legacy Pairing
还是Secure Connections Pairing
模式来进行配对,原则是:只有双方都设置了Secure Connections Pairing
标志,才会使用这种配对模式,否则使用Legacy Pairing
。
阶段2:判断是否支持OOB。对于Legacy Pairing
模式,只有双方均支持OOB,才会使用OOB方式。对于Secure Connections Pairing
模式,如果Initiator
支持OOB,则使用OOB方式。
阶段3:检查MITM(中间人)。如果配对双方都没有配置MITM标志,则直接使用Just Works
方法来配对,否则按照双方的IO能力来选择配对方法。
阶段4:根据双方的IO能力来选择配对方法。
关于阶段2 ~ 阶段4的具体说明可以参考蓝牙官方手册文档《BLUETOOTH SPECIFICATION Version 4.2 [Vol 3, Part H]》的 *2.3.5.1 Selecting Key Generation Method* 章节的内容。
ble.smpGetConfig
ble.smpGetConfig(io_cap, auth_req, passkey, timeout)
配对能力查询。
返回值描述:
执行成功返回值如下,失败返回整型-1。
io_cap
-设备输入输出能力,类型为整型,默认为3。
值 | 含义 |
---|---|
0 | 只有显示能力,可以显示PIN码 |
1 | 只有显示能力,只能显示Yes/No,不能显示PIN码 |
2 | 只有输入能力,可以输入PIN码 |
3 | 没有输入输出能力 |
4 | 有输入输出能力,既可以显示PIN码,又可以输入PIN码 |
auth_req
-认证请求参数,类型为整型,默认为9。
Bit0 | Bit1 | Bit2 | Bit3 | |
---|---|---|---|---|
0 | 配对后不绑定 | 预留,无实际含义 | 不启用MITM | 使用Legacy Pairing |
1 | 配对后绑定 | 预留,无实际含义 | 启用MITM | 使用Secure Connections Pairing |
passkey
-配对显示的PIN码,类型为整型,默认为123456。timeout
-配对超时时间,单位为100ms,类型为整型,默认为160。
ble.smpStartPair
ble.smpStartPair(connect_id)
开始BLE SMP配对流程。SMP配对由client发起,server也可以通过该接口来通知client发起SMP配对请求。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.smpUserConfirm
ble.smpUserConfirm(connect_id, pair_operation, pin)
确认配对。收到配对请求后确认是否接受配对。
参数描述:
connect_id
-连接ID,建立连接时得到的连接ID,类型为整型。pair_operation
-配对的操作类型,类型为整型。
值 | 含义 |
---|---|
0 | 取消配对,只有在配对过程中,才能执行该操作。取消配对会导致蓝牙连接断开。 |
1 | 确认配对,不携带PIN码(用于Just Work或者Numeric Comparison模式) |
2 | 确认配对,携带PIN码(用于Passkey模式) |
pin
-PIN码,类型为整型。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.smpGetPairedDevInfo
ble.smpGetPairedDevInfo()
获取已配对设备信息。
返回值描述:
执行成功返回值如下,失败返回整型-1。
addr_list
-已配对设备的BLE地址列表,类型为list,list成员为bytearray类型的BLE地址。
ble.smpRemovePairedDev
ble.smpRemovePairedDev(addr)
删除指定的已配对设备信息。
参数描述:
addr
-待删除的设备BLE地址,类型为bytearray,大小为6字节。
返回值描述:
执行成功返回整型0,失败返回整型-1。
ble.smpCleanPairedDev
ble.smpCleanPairedDev()
删除所有已配对设备信息。
返回值描述:
执行成功返回整型0,失败返回整型-1。
注意:以上BLE SMP相关接口均需要在BLE已经初始化的情况下执行,否则会返回失败。当前仅EC200UEUAA型号特定固件支持BLE SMP功能。