600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 小程序蓝牙BLE——自动连接设备(手环)

小程序蓝牙BLE——自动连接设备(手环)

时间:2019-08-26 18:24:10

相关推荐

小程序蓝牙BLE——自动连接设备(手环)

了解小程序蓝牙API:

/** *蓝牙API: * 1.初始化蓝牙(判断蓝牙是否可用);openBluetoothAdapter* 2.获取蓝牙设备状态(蓝牙是否打开);getBluetoothAdapterState* 3.监控蓝牙打开/关闭的动作;onBluetoothAdapterStateChange* 4.开始搜索周围是否有设备;startBluetoothDevicesDiscovery* 5.获取周围设备列表;getBluetoothDevices* 6.停止搜索周围设备,减少消耗资源;stopBluetoothDevicesDiscovery* 7.过滤目标设备;* 8.是否已经连接蓝牙设备:* a.获取已经连接的蓝牙设备;getConnectedBluetoothDevices* b.创建新的低功耗蓝牙设备连接deviceId;createBLEConnection* 9.获取设备的信息* a.获取蓝牙设备的服务码;getBLEDeviceServices* b.获取蓝牙设备的特征值;getBLEDeviceCharacteristics* c.获取蓝牙设备的write和notify服务;readBLECharacteristicValue* 10.向蓝牙设备写入指令;writeBLECharacteristicValue* 11.只有,开启蓝牙设备的notify提醒功能;notifyBLECharacteristicValueChange* 12.才能,监听接受蓝牙设备返回的数据;onBLECharacteristicValueChange* 13.断开低功耗的蓝牙连接;closeBLEConnection* 14.关闭蓝牙,释放资源:closeBluetoothAdapter* * */

编程逻辑步骤:

/*** 第一部分:蓝牙设配器* 1.微信小程序:是否支持* 2.手机蓝牙:是否可用;* 3.手机蓝牙:是否开启* 4.监听开启手机蓝牙状态的事件* */ /*** 第二部分:开启搜索、过滤、连接、关闭搜索* 1.搜索设备;* 2.获取设备列表;* 3.连接设备,成功后关闭实时搜索;** *//*** 第三部分:服务值、特征、write和notify服务* 1.获取服务值;* 2.特征;* 3.write和notify服务* * *//*** 第四部分:向蓝牙写入指令、监控接受数据* 1.写入指令;*对应命令转为16进制的形式*START = [83, 84, 65, 82, 84]+时间戳*STOP = [83, 84, 79, 80]*REQDATA = [82, 69, 81, 68, 65, 84, 65]*AUTO_ACC= [ ...] * 2.监控接收数据;* * *//*** 第五部分:断开连接* 1.断开蓝牙;* 2.清楚缓存* */

断开后、自动连接(半成熟):

wx.onBluetoothAdapterStateChange();//监听蓝牙适配器状态变化事件,判断连接状态;

wx.getConnectedBluetoothDevices();//是否有已连接设备,否根据安卓deviceId||苹果uuid唯一识别符重新: wx.getBLEDeviceServices()-->....-->wx.createBLEConnection()重新自动连接;

附录:蓝牙设备的硬件的知识点:

硬件字节

ArrayBuffer:类型化数组,JavaScript操作二进制数据的一个接口。 WebGL,指浏览器与显卡之间的通信接口,为了满足JavaScript与显卡之间大量的、实时的数据交换,它们之间的数据通信必须是二进制的,而不能是传统的文本格式。 比如,以文本格式传递一个32位整数,两端的JavaScript脚本与显卡都要进行格式转化,将非常耗时。这时要是存在一种机制,可以像C语言那样,直接操作字节,然后将4个字节的32位整数,以二进制形式原封不动地送入显卡,脚本的性能就会大幅提升。 类型化数组(Typed Array)就是在这种背景下诞生的。它很像C语言的数组,允许开发者以数组下标的形式,直接操作内存。有了类型化数组以后,JavaScript的二进制数据处理功能增强了很多,接口之间完全可以用二进制数据通信。

ArrayBuffer作为内存区域,可以存放多种类型的数据。不同数据有不同的存储方式,这就叫做“视图”。目前,JavaScript提供以下类型的视图:

Int8Array:8位有符号整数,长度1个字节。

Uint8Array:8位无符号整数,长度1个字节。

Int16Array:16位有符号整数,长度2个字节。

Uint16Array:16位无符号整数,长度2个字节。

Int32Array:32位有符号整数,长度4个字节。

Uint32Array:32位无符号整数,长度4个字节。

Float32Array:32位浮点数,长度4个字节。

Float64Array:64位浮点数,长度8个字节。

parseInt(s, 16)//十六进制字符串转字节数组

str.toString(16)//字节数组转十六进制字符串

float:浮点数

unsigned:无符号

int :向下取整

char:字符

ArrayBuffer:类型化数组

客户端要产生一个唯一的标识符:deviceId、MAC地址、AndroidId:

AndroidId:

获取AndroidId是不需要权限的但是AndroidId是可能变的,AndroidId是在用户第一次激活这个设备时产生的所以当用户重置手机时AndroidId会产生变化,理论上这个AndroidId是可以接受的毕竟重置手机这个事发生也不会太频繁;

MAC地址:

可以使用WIFI的MAC地址来作为标识符,感觉现阶段这种方式比较可靠总结如下:Mac地址是唯一的,直接产生在硬件上基本上不会变更;

DeviceId:

区别设备唯一设备ID。

其他:

1、profile

profile可以理解为一种规范,一个标准的通信协议,它存在于从机中。蓝牙组织规定了一些标准的profile,例如 HID OVER GATT ,防丢器 ,心率计等。每个profile中会包含多个service,每个service代表从机的一种能力。蓝牙设备可以包括多个Profile,一个Profile中有多个Service,

2、service服务

service可以理解为一个服务,在ble从机中,通过有多个服务,例如电量信息服务、系统信息服务等,每个service中又包含多个characteristic特征值。每个具体的characteristic特征值才是ble通信的主题。比如当前的电量是80%,所以会通过电量的characteristic特征值存在从机的profile里,这样主机就可以通过这个characteristic来读取80%这个数据;一个Service中有多个Characteristic,

3、characteristic特征

characteristic特征值,例如:read、notify、write等特征…;ble主从机的通信均是通过characteristic的read、write来实现,可以 理解为一个标签,通过这个标签可以获取或者写入想要的内容。

4、UUID

UUID,统一识别码,我们刚才提到的service和characteristic,都需要一个唯一的uuid来标识

每个从机都会有一个叫做profile的东西存在,不管是上面的自定义的simpleprofile,还是标准的防丢器profile,他们都是由一些列service组成,然后每个service又包含了多个characteristic,主机和从机之间的通信,均是通过characteristic来实现。

实际产品中,每个蓝牙4.0的设备都是通过服务和特征来展示自己的,服务和特征都是用UUID来唯一标识的。一个设备必然包含一个或多个服务,每个服务下面又包含若干个特征。特征是与外界交互的最小单位。蓝牙设备硬件厂商通常都会提供他们的设备里面各个服务(service)和特征(characteristics)的功能,比如哪些是用来交互(读写),哪些可获取模块信息(只读)等。比如说,一台蓝牙4.0设备,用特征A来描述自己的出厂信息,用特征B来与收发数据等。

参考:

蓝牙核心技术了解(蓝牙协议、架构、硬件和软件笔记)

实战分享,教你蓝牙在小程序中的应用

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。