Android 蓝牙开发(3)——蓝牙的详细介绍

摘要:
前面两篇文章主要是基于安卓官网对蓝牙的介绍和我自己的理解。它主要针对Android开发中某些API的使用。第二篇文章主要介绍了低功耗蓝牙的发展。蓝牙蓝牙技术的发展历史最初由爱立信创造。到2014年,Android 5.0也将支持外围模式。该层在协议栈中是可选的。一些小型终端可能没有,但它必须在Android设备上可用。该层是蓝牙上层和芯片之间交互的唯一方式。对于蓝牙硬件开发人员来说,这里的日志可以很好地解决问题。

前面的两篇文章,主要是在 Android 官网关于蓝牙介绍的基础上加上自己的理解完成的。主要针对的是 Android 开发中的一些 API 的使用。
第一篇文章 Android 蓝牙开发(1) 主要是介绍了普通的蓝牙在 Android 开发中的运用。
第二篇文章 Android 蓝牙开发(2) 主要是介绍了低功耗蓝牙的开发。
这篇文章主要介绍的是蓝牙的历史和一些关于蓝牙的通用知识,还有广播包的知识。要想彻底了解蓝牙开发,这些基础的知识也是需要的,就像网络协议一样,这些都是基础的内容。我们的 API 的调用都是以这个为基础的,了解这些,开发过程中遇到问题,才可以知道什么怎么一回事。

下篇文章主要讲的就是实际开发中的一些坑。

Android 蓝牙开发(3)——蓝牙的详细介绍第1张

蓝牙的发展历史

蓝牙技术最初是由爱立信创制的。技术始于爱立信公司 1994 方案,它是研究在移动电话和其他配件间进行低功耗、低成本无线通信连接的方法。发明者希望为设备间的通讯创造一组统一规则(标准化协议)用来解决用户间相互不兼容的移动电子设备。

1998 年 5 月 20 日,索尼以立信、国际商业机器、英特尔、诺基亚及东芝公司等业界龙头创立“特别兴趣小组”(Special Interest Group SIG),即蓝牙技术联盟的前身,目标是开发一个成本低、效益高、可以在短距离范围内随意无线连接的蓝牙技术标准。负责蓝牙规范的制定和推广的国际组织。

1998年推出了 0.7 规格,1999 年推出了 0.8、0.9等等。1999 年 7 月正式公布 1.0 版本,使用 2.4GHz频谱,最高资料传输速度 1Mbps。2001 年的 1.1 版本正式列入 IEEE 标准。

蓝牙其实就是一种近距离无线通信技术。

蓝牙历史版本.png

  • 低功耗蓝牙 BLE

    全称是 Bluetooth Low Energy 简称 BLE 。最大的特点就是低功耗,有些 BLE 设备一个纽扣电池可以使用一两年。这对于现在的穿戴设备以及各种物联网传感器来说是一个很大的突破。同时它的传输的数据就很少。

  • 在 Android 4.3 的时候开始支持低功耗蓝牙。仅仅支持中心模式,就是只可以连接其他蓝牙外设。到了 2014 年 Android 5.0 开始也支持周边模式。

协议栈

蓝牙协议栈.png
图片来自网络

从下到上分别为:控制器(Controller)-->主机(host)-->应用(Application)

控制器:协议栈的底层的实现,直接和硬件相关,由芯片厂商实现,包括物理层、链路层、主机控制接口。

主机:协议栈的上层实现是硬件的抽象,与具体的硬件厂商没有关系。

应用层:使用主机层提供的 API 开发的应用。

详细介绍各个层的含义:

  • PHY(Physical Layer)物理层,蓝牙是工作在 2.4GHz 附近,这是工业、科学、医疗 ISM 的频段,免许可证。WIFI 也是工作在同一个频段。蓝牙把频段切分为 40 个通道,其中 3 个广播通道,37 个数据通道,按照一个规律跳频通信。

  • LL(Linker Layer)链路层,用于控制设备的射频状态,设备将处于五种状态之一:等待、广告、扫描、初始化、连接。广播设备不需要建立连接就可以发送数据,而扫描设备接受广播设备发送的数据;发起连接的设备通过发送连接请求来回应广播设备,如果广播设备接受请求,那么广播设备与发起连接的设备将会进入连接状态。发起连接的设备称为主机,接受连接请求的设备称为从机。

  • HCI(Host Controller Interface):主机和控制器就是通过这个接口来进行通讯的,通讯的介质就是 HCI 命令。这层在协议栈中是可选的,一些小型终端可能没有,但是 Android 设备上肯定有,这层是蓝牙上层和芯片的交互必经之路,对于蓝牙硬件开发者,这里的 log 能够很好的帮助解决问题。

  • HOST 部分要复杂。有链路控制和适配层(L2CAP),安全管理(SM)等。重点看属性协议层,也就是 ATT。它是整个 BLE 通信的基础。ATT负责数据封装,向外暴露为 “属性”,提供“属性”的为服务端,获取“属性”的为客户端。ATT 是专门为 BLE 低功耗蓝牙而设计的传输协议,结构简单,传输数据短。

  • GATT(Generic Attribute Profile):全称叫做通用属性配置文件,是基于 ATT 做的进一步的逻辑封装,定义数据的交互方式和含义,APP 开发就是用的这一层。GATT 定义了三个非常重要的概念:服务(Service)、特征(Characteristic)、描述(Descripter)。他们的关系如下图

gatt内部组成.png

一个 Service 可以包含若干个 Characteristic,一个 Characteristic 可以包含属性(properties)和值(value),还可以包含多个 descripter 。Characteristic 实际上具有读、写、通知等权限。我们在对一个 BLE 设备发起连接成功以后,对他进行读写操作,其实就是对 Characteristic 的操作。图中的 Profile 是一组服务的集合,这些服务组个起来就形成了一个特定的使用场景了,里面的服务是嵌入式工作人员可以添加的。BLE 蓝牙使用 UUID 来区分 Service、Characteristic 、Descripter。

  • GAP(Generic Access Profile):通用访问控制配置文件。定义了 BLE 整个通信过程中的流程,负责处理设备访问模式和程序,包括设备发现、建立连接、终止连接等等。GAP 层总是作为下面四种角色之一:(1)广播者:不可连接的广播设备。(2)观察者:扫描设备,但不发起建立连接 (3)外部设备:可连接的广播设备,可以在单个链路层连接中作为从机。(4)集中器:扫描广播设备并发起连接,可以在单链路层连接中作为主机。

应用开发

BLE 应用可以分为两大类:基于非连接的和基于连接的

基于非连接的:

意思就是外设和周边设备不发生连接,主要靠扫描到的广播来获取信息。发送广播的一方叫做 broadcaster 监听广播的一方叫做 oberver 在 GAP 层有对应的角色定义。

网络拓扑图:

非连接网络拓扑图.png

这种方式就是广播设备不断的向外发送广播(含有特定的信息),然后观察者接受到广播按照两者之间约定好的协议进行解析拿到有用的信息。例如:iBeacon,通过这种设备我们可以实现室内定位。

其实这些设备的角色可以即使广播者又是观察者。接收到广播后作出了处理,然后又发送广播。这样就形成了双向的网络,类似于因特网,这就是蓝牙 Mesh 组网。

广播数据包格式:

广播数据包.png

每个广播数据包由 31 byte 组成。分为有效数据和无效数据两部分。

  • 无效数据部分:因为广播数据包的长度必须是 31 字节,如果有效数据不够 31 个字节那么剩下的就用 0 来补全。这一部分就是无效的,也就是无效数据。
  • 有效数据部分:包含若干个广播数据单元,称为 AD Structure。每个 AD Structure 的组成格式是:第一个字节是长度值 Length,表示接下来的 Length 个字节是数据部分。数据分别的第一个字节表示数据类型 AD Type,剩下的 Length - 1 是真正的数据。数据类型很重要,有标准的规定,决定了数据代表什么意思和怎么解析

例子:

E/TAG:scandata:02011A05FFAC0134560000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000

这里是扫描的数据包(转换成了 16 进制,两个代表一个字节),第一个字节是 02 表示后面的两个字节是数据部分,然后第二个字节是 01 表示了数据的类型。后面一个字节就是真正的数据了。这个广播数据单元就分析完了。下面就是另一个数据单元了。依次类推,关于数据类型的解释,官网有。

数据类型.png

这是数据类型对应的含义表。

基于连接的:

就是两个设备建立 GATT 连接,需要双方进行通信。这里的两个角色是,外设设备(Peripheral)和中心设备(一般是手机)Centeral。

网络拓扑图:

连接网络拓扑图.png

一个中心设备可连接多个外设,但是一个外设只能连接一个中心(外设连接成功后就会停止对外广播,别人就发现不了它了)。其中一个中心设备的连接外设的数量也是有限的。

Android 蓝牙开发(3)——蓝牙的详细介绍第9张

免责声明:文章转载自《Android 蓝牙开发(3)——蓝牙的详细介绍》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇MySQL:参数wait_timeout和interactive_timeout以及空闲超时的实现【转】白鹭和layabox H5游戏开发引擎比较下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

用树莓派玩转蓝牙

作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁转载。 蓝牙是一个使用广泛的无线通信协议,这两年又随着物联网概念进一步推广。我将介绍蓝牙协议,特别是低功耗蓝牙,并用树莓派来实践。树莓派3中内置了蓝牙模块。树莓派通过UART接口和该模块通信。树莓派1和树莓派2中没有内置的蓝牙模块,不过你可以通过USB安装额外的蓝牙适配器...

LED时钟同步之无线传输设计方法

深圳市立显电子有限公司,专业LED时钟生产厂家!--------【点击进入】 无线同步时钟功能说明: 标准wifi同步时钟采用3/4/5英寸单红数码管、恒流驱动设计。可根据客户要求订制显示布局:年、月、日、时、分、秒、星期等时间元素。机身采用黑色铝合金边框设计,美观大方、坚固耐用。LED时钟无线联网对时符合IEEE802.11b/g/n网络规范,为实现网络...

GOOSE信息交换方式

GOOSE采用发布者/订阅者模式实现设备间的通信,发布者/订阅者模式可用来实现站内快速、可靠的发送输入和输出信号量,可利用重传机制保证通信的可靠性。发布者/订阅者模式是一个数据源(发布者)向多个接收者(订阅者)发送数据的最佳方案,尤其是用于数据流量大且实时性要求高的数据通信。 GOOSE报文发送采用心跳报文和变位报文快速重发相结合的机制。当有IEC6185...

[虚拟化/云][全栈demo] 为qemu增加一个PCI的watchdog外设(六)

目的: 1. 为我们自己的watchdog写一个驱动 步骤: 通过之前的介绍,我们很容易猜想到写我们基于PCI的watchdog驱动,可以分2个步骤。 1. 探测加载PCI设备 这部分代码跟我们的设备本身没有任何关系。 我们通过这部分代码,找到 厂商ID为 0x1af4, 设备ID为0x0101的设备。这个设备是我们用qemu中定义我们的watchdog中...

进程之间的通信

进程/线程同步的方式和机制,进程间通信 一、进程/线程间同步机制。 临界区、互斥区、事件、信号量四种方式临界区(Critical Section)、互斥量(Mutex)、信号量(Semaphore)、事件(Event)的区别1、临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。在任意时刻只允许一个线程对共享资源进行访问,如果...

Android系统Binder机制学习总结

一、Binder机制概述 在Android开发中,很多时候我们需要用到进程间通信,所谓进程间通信,实现进程间通信的机制有很多种,比如说socket、pipe等,Android中进程间通信的方式主要有三种: 1.标准Linux Kernel IPC 接口; 2.标准D-BUS接口; 3.Binder接口。 其中,Binder机制是使用最且最被认可的,因为Bi...