android停止蓝牙音乐服务,蓝牙音乐播放状态一直为暂停态

安卓源码避坑指南7——蓝牙音乐播放状态一直为暂停态

9e7812e691479d560122292af00460fc.png

蓝牙音乐的播放状态是蓝牙音乐等相关应用重点关心的变量,应用根据该状态值(播放、暂停)实时更新界面图标显示。本期就和大家简单分享下蓝牙音乐播放状态上报错误的源码问题。

播放状态都是通过AVRCP协议从手机端获取过来的,还不了解的同学查看前面的AVRCP系列文章,相信能给大家提供帮助。

CT控制端获取播放状态有两种方法:

1、AVRCP Get Play Status

2e1e43689510ac319e60ca2c2d986517.png

2、AVRCP Register Notification(Event = Playback)

057b8057eb0aec9a89e392730d7eebb3.png

方法1是蓝牙协议栈bluedroid通过命令AVRCP Get Play Status可以获取到当前的播放状态及进度条信息,但是该命令只有音乐播放时才会触发2s的定时器循环获取,而且获取到信息只会将进度条Position上报,其他信息不做处理,因此该命令在现有的安卓系统中无法满足音乐应用的需求。

方法2则是通过命令AVRCP Register Notification注册一个Playback事件的通知,当播放状态改变时,手机端TG会主动通知到CT端,该方法获取到的播放或暂停状态才符合应用的要求。

通过注册通知命令获取播放状态在安卓系统的时序图如下:

38a56f0c04d9d76bcbae3aee24a5f58f.png

音乐播放状态值最终保存在AvrcpPlayer.mPlayStatus变量中,后续蓝牙服务对外广播当前的音乐播放状态也是获取该值广播出去的。

按照通常的分析,该值应该一直保存着最新的手机通知的状态值,然而事实却非如此…

问题环境:高通安卓系统(android-9)

问题现象:蓝牙音乐实际在播放中,可CT控制端上报给应用的播放状态一直为Pause态

f010c3b7c7e8885d25942f43160f6f6b.png

详细的播放状态值在PlaybackState类中有定义:Pause = 2、Playing = 3。

不知大家在蓝牙音乐开发使用的过程中是否有遇到这种问题,我首先怀疑是手机本身通知的状态有误,查看HCI文件后打消了这种想法。

ab4cf3f8e31d3250b51117d1f29da731.png

AvrcpPlayer.mPlayStatus值是在什么时候被改写了?

带着这个疑点查看源码,可知AvrcpPlayer.mPlayStatus变量只有在AvrcpPlayer.setPlayStatus()方法调用才会被重写,但是这个方法只会在手机通知播放状态变化时才会调用到,但分析完HCI后,手机通知的状态值明显都是正确值 Playing,那怎么无缘无故变成Pause ?

分析到这儿,不知大家是否困惑了,反正我已经…

e94983c2648bd2a83ce77f9ec5675f0f.png

继续查看logcat,终于发现问题所在:更新音乐播放器AvrcpPlayer相关信息时,高通安卓源码中还新增了更新播放器对象mAddressedPlayer的操作,从而间接改变了AvrcpPlayer.mPlayStatus的值。

播放器的更新也是通过注册一个Players和Player事件的通知来实现的,CT控制端接收到播放器改变的通知后使用命令AVRCP Get Folder Items获取播放器信息,最终在AvrcpControllerStateMachine状态机中通过msg.what = MESSAGE_PROCESS_GET_PLAYER_ITEMS更新播放器信息。

8bc7502f1c7028b925604e784d5f1461.png

由于手机回复AVRCP Get Folder Items的信息中Play Status = Paused :

037886228813c62373e68d03ffd46418.png

从而将AvrcpPlayer.mPlayStatus值从 Playing变为Pause:

745a7428f09a12a7606938e092e466a5.png

解决方案:更新播放器对象mAddressedPlayer前,将旧播放器对象中的 mPlayStatus值更新到新播放器对象中进行保存。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值