问题描述
当我在OnePlus上打开蓝牙时,MediaBrowserServiceCompat
将启动。
我的第一个logcat条目来自我的类中的onCreate()
方法,扩展了MediaBrowserServiceCompat
。其他几个媒体播放器应用也会启动。
logcat中没有太多有关蓝牙为何以及如何触发MediaBrowserServiceCompat
的信息。因此,我迷路了。该行为并非完全可重现,但是会发生9/10次,尤其是在打开我的蓝牙耳机的情况下。仅连接耳机不会导致相同的行为。仅打开设备上的蓝牙即可。
当打开蓝牙时,是什么导致MediaBrowserServiceCompat
启动,或者如何找出导致它的原因?反过来,我该如何防止这种行为呢?
解决方法
根据https://developer.android.com/guide/topics/media-apps/mediabuttons#restarting-inactive-mediasessions
如果Android可以识别上一个活动的媒体会话,它将尝试通过将ACTION_MEDIA_BUTTON Intent发送到清单注册的组件(例如服务或BroadcastReceiver)来尝试重新启动会话。这样一来,您的应用在用户界面不可见时就可以重新开始播放,大多数音频应用就是这种情况。
我认为在您的情况下,由于您的应用程序是最后一个活动的MediaSession,因此系统正在尝试重新启动MediaBrowserService。尝试通过切换到其他媒体应用程序(然后连接BT)来调试应用程序,然后检查系统是否启动了您的服务。
另外,请检查https://developer.android.com/guide/topics/media-apps/mediabuttons以获得更多信息。