蓝牙音乐之AVRCP

蓝牙AVRCP版本(蓝牙音乐之AVRCP)(1)

蓝牙音乐实实在在地改变了我们听音乐的方式,尤其是iphone推出真无线耳机后,这一趋势更加明显。蓝牙音乐中不单单涉及到A2DP,对A2DP还不了解的小伙伴可以查看《蓝牙音乐之A2DP 》,还有音乐远端控制功能(播放、暂停、切换歌曲等),而这些功能的实现都依赖于AVRCP协议。

AVRCP:Audio/Video Remote Control Profile,音视频远端控制协议,所以该协议不但能控制蓝牙音乐,也可以控制视频流相应的功能。常见的使用到AVRCP控制功能的场景有如下几种:

  1. 耳机或车载等蓝牙设备控制其他设备上的音乐音源播放(手机)
  2. 远端设备控制其他设备上的视频播放
  3. 远端设备控制手机拍照(手机前台应用为照相机)

AVRCP协议版本变化,版本之间都是向下兼容的关系:

  1. 项目的数量,用于控制器的接口,请求和接收文件夹中的项数,而无需下载列表
  2. 封面艺术,支持通过基于OBEX协议上的 BIP(Basic Imaging Profile)协议将图像传输到媒体项目

所以如果两端设备的AVRCP协议都支持1.6及以上,则可实现通过蓝牙传输图片的功能。由于蓝牙传输数据量的限制,该功能也只是适用于音乐专辑封面照等小数据量的传输,而不适合大批量图片的传输。

至此,最新的v1.6版本的AVRCP协议结构及依赖关系如下:

蓝牙AVRCP版本(蓝牙音乐之AVRCP)(2)

AVRCP协议的核心概况如下:

蓝牙AVRCP版本(蓝牙音乐之AVRCP)(3)

类似于其他蓝牙协议,AVRCP协议也将设备两端划分为两种角色:

需要注意的是,通常情况下CT和TG都是成对出现在同一个piconet网中,但是同一个piconet网中可以存在多个CT设备,比如同一个手机(TG)可以同时连接多个耳机(CT)。常见的关系图如下:

蓝牙AVRCP版本(蓝牙音乐之AVRCP)(4)

从上面的概况图可知AVRCP协议的传输依赖于AVCTP,所以AVRCP协议的连接、交互实际上是AVCTP传输协议的连接、交互流程。

AVCTP的连接建立

用于AVCTP控制的L2CAP链路的连接建立可以由CT或TG启动,此L2CAP链路称为控制通道。如果设备双方都支持浏览功能(AVRCP版本都在v1.4及以上),则还可以在控制通道建立后再建立一条浏览通道,浏览通道在建立时应配置为使用L2CAP增强重传模式。同理通道的释放也可以由CT或TG启动,如果存在浏览通道则需要在控制通道断开前释放。

如果两端设备同时打开AVCTP通道建立连接,双方检测到连接冲突后两个通道都应关闭,每端设备应该等待随机时间(100ms <= time <= 1s),然后再尝试打开AVCTP通道。如果知道哪个设备是主设备,则该设备可以立即重新尝试连接。

实际使用过程中AVCTP的连接都会在AVDTP(A2DP协议依赖的传输协议)连接成功后由CT端设备主动发起连接,当然GT端设备可选择性的也发起主动连接。

AVRCP中基本AV/C命令

AV/C命令启动的前提是AVCTP的连接已建立,这样由用户触发或程序内部启动的AV/C流程才可正常运作,大致流程图如下:

蓝牙AVRCP版本(蓝牙音乐之AVRCP)(5)

OBEX的连接和断开

AVRCP(v1.6版本及以上)使用来自BIP协议通用成像图像特性中定义的功能来提供封面艺术图片,而BIP又依赖于OBEX。所以封面艺术OBEX连接时使用的目标标头为封面艺术专属的 UUID=7163DD54-4A7E-11E2-B47C-0050C2490048

链路建立成功后,AVRCP的CT端设备具有BIP成像发起者的作用,而对应的AVRCP的GT端设备具有BIP成像应答器的作用。

AVRCP命令的类型:

1、AV/C命令,通过AVCTP的控制通道交互,存在如下两组命令:

  1. 在AV/C规范中定义的Pass Through命令、UNIT和SUBUNIT INFO命令,常用的播放、暂停、上下首切歌等控制命令都是Pass Through命令
  2. AVRCP特有的AV/C命令

2、浏览命令,通过AVCTP的浏览通道交互

3、封面艺术命令,通过OBEX建立的连接交互

AVRCP协议中特有的常见命令如下图所示:

蓝牙AVRCP版本(蓝牙音乐之AVRCP)(6)

更多AVRCP指令就留待大家在实际使用过程中探索了,本期的AVRCP协议分享就到这儿感兴趣的小伙伴欢迎私信留言一起讨论,共同学习,一起进步!

参考文件:

《AVRCP_v1.6.2.pdf》

《AVCTP_SPEC_V14.pdf》

,