车载端蓝牙AVRCP获取音乐信息btsnoop 分析

文章详细探讨了车载蓝牙音乐功能中的常见问题,如暂停延迟、播放状态不同步、歌曲信息错误等,并通过AVRCP协议解释了播放、暂停、切歌的交互过程。解决方案包括优化通知间隔和定期获取播放状态以解决进度条跳动及信息同步问题。
摘要由CSDN通过智能技术生成

近几年新能源车载火出了天际,各个厂商新势力转战新能源!

车载设备开发,软件娱乐系统,离不开蓝牙,对蓝牙稳定性要求也越来越高,对于车载使用蓝牙音乐的功能,主要有以下这些,通过AVRCP控制歌曲暂停、播放、上一曲、下一曲,同步手机端歌曲信息 进度、作者、歌词、播放状态、音量同步等

经常也会遇到以下的一些问题:

车载点击暂停/播放,为什么几秒后才暂停/播放?

车载点击暂停/播放,为什么实际没有暂停/播放?

车载点击暂停,实际声音暂停,歌曲信息一直在更新,为什么?

车载进度position和手机端不同步?

车载播放显示歌曲信息和手机端不一致?

车载进度position 2-3s 跳动一次,为什么?

车载播放歌曲作者显示成歌词,为什么?

车载播放不显示歌曲歌词信息等?

希望在以下的讲解中能够自行找到答案,另外AVRCP中 CT TG概念,通知 event等请在以前文章中自行翻阅,不再重复解释,下面进入正文

1.播放

播放的按键触发为一组按下抬起动作,对应btsnoop为首先车载host下发play的Button Pushed手机回应accept,随后按键抬起车载host下发Button Released,对应手机accept,完成播放按键的下发

按键下发不代表音乐成功播放,此时手机端过来一个CHANGE的回应,携带的play status为playing状态,则成功从车载端触发播放,一开始注册通知事件EVENT PLAYBACK STATUS CHANGED则是在AVRCP刚连上的时候,INTERIM为paused状态,change playing事件完成后,一组通知结束,车载host继续注册通知EVENT PLAYBACK STATUS CHANGED,手机controller回复INTERIM(中间态)为playing状态,等待下一次的change response



 2.暂停

暂停的按键事件也是对应一组按下抬起,与play有差异的则是Operation Id标志为pause

 接播放的interim---playing状态,此时手机端过来EVENT PLAYBACK STATUS CHANGED的change事件,把播放状态切换为paused状态,此时标志暂停成功,然后继续重复注册下一次通知

3.上一曲

同样是一组键值按下抬起,Operation Id为backward,然后是暂停状态下切歌,手机会直接过来更新通知至playing状态拉起播放,另外切歌会对应一组EVENT TRACK CHANGED的通知变化
 

 4.下一曲

对应Operation Id为forward,且是在播放状态切歌,此时我们可以看到,手机端先更新了一下paused状态再更新为playing状态,但值得注意的是蓝牙用于传输音频数据的AVDTP则一直处于start状态未进行suspend

 5.歌曲进度position

蓝牙音乐的歌曲信息position在连上AVRCP时就会注册通知

参数:Playback interval in seconds: 1(告诉手机端需要1s更新一次position给车载)

实际Android源码中一般默认为2s/3s更新一次,那歌曲进度会一直2-3s跳动一下进度吗?实际不会,车载端 Android还会通过get play status 每秒去获取手机端播放状态和进度,如果不去每秒get play status,则会出现2-3s跳进度条问题,所以直接设置Playback interval in seconds为1,每秒更新则可以完美解决该问题

 手机端从controller每1s更新position通知,同时车载host每秒去Get Play Status更新position

6.歌曲信息

 蓝牙通过Get Element Attribute去更新歌曲信息,获取歌曲时长、标题、作者、歌词等信息
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值