Когда действие получает метод обратного вызова жизненного цикла onCreate()
оно должно выполнить следующие шаги:
- Создайте и инициализируйте медиа-сессию
- Установите обратный вызов медиа-сеанса
- Установите для приемника медиа-кнопки сеанса мультимедиа значение null, чтобы событие медиа-кнопки не перезапускало проигрыватель, когда он не виден. Это касается только устройств Android 5.0 (уровень API 21) и более поздних версий.
- Создайте и инициализируйте медиа-контроллер.
Код onCreate()
ниже демонстрирует эти шаги:
Котлин
private lateinit var mediaSession: MediaSessionCompat public override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) // Create a MediaSessionCompat mediaSession = MediaSessionCompat(this, LOG_TAG).apply { // Enable callbacks from MediaButtons and TransportControls setFlags(MediaSessionCompat.FLAG_HANDLES_MEDIA_BUTTONS or MediaSessionCompat.FLAG_HANDLES_TRANSPORT_CONTROLS) // Do not let MediaButtons restart the player when the app is not visible setMediaButtonReceiver(null) // Set an initial PlaybackState with ACTION_PLAY, so media buttons can start the player val stateBuilder = PlaybackStateCompat.Builder() .setActions(PlaybackStateCompat.ACTION_PLAY or PlaybackStateCompat.ACTION_PLAY_PAUSE) setPlaybackState(stateBuilder.build()) // MySessionCallback has methods that handle callbacks from a media controller setCallback(MySessionCallback()) } // Create a MediaControllerCompat MediaControllerCompat(this, mediaSession).also { mediaController -> MediaControllerCompat.setMediaController(this, mediaController) } }
Ява
MediaSessionCompat mediaSession; PlaybackStateCompat.Builder stateBuilder; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // Create a MediaSessionCompat mediaSession = new MediaSessionCompat(this, LOG_TAG); // Enable callbacks from MediaButtons and TransportControls mediaSession.setFlags( MediaSessionCompat.FLAG_HANDLES_MEDIA_BUTTONS | MediaSessionCompat.FLAG_HANDLES_TRANSPORT_CONTROLS); // Do not let MediaButtons restart the player when the app is not visible mediaSession.setMediaButtonReceiver(null); // Set an initial PlaybackState with ACTION_PLAY, so media buttons can start the player stateBuilder = new PlaybackStateCompat.Builder() .setActions( PlaybackStateCompat.ACTION_PLAY | PlaybackStateCompat.ACTION_PLAY_PAUSE); mediaSession.setState(stateBuilder.build()); // MySessionCallback has methods that handle callbacks from a media controller mediaSession.setCallback(new MySessionCallback()); // Create a MediaControllerCompat MediaControllerCompat mediaController = new MediaControllerCompat(this, mediaSession); MediaControllerCompat.setMediaController(this, mediaController); }
Когда приложение закрывается, активность последовательно получает обратные вызовы onPause()
и onStop()
. Если игрок играет, вы должны остановить его, прежде чем его активность исчезнет. Выбор того, какой обратный вызов использовать, зависит от того, какую версию Android вы используете.
В Android 6.0 (уровень API 23) и более ранних версиях нет гарантии того, когда будет вызван onStop()
; он может быть вызван через 5 секунд после исчезновения вашей активности. Поэтому в версиях Android ниже 7.0 ваше приложение должно остановить воспроизведение в onPause()
. В Android 7.0 и более поздних версиях система вызывает onStop()
как только активность становится невидимой, поэтому это не проблема.
Подводя итог:
- В Android версии 6.0 и более ранних версиях остановите проигрыватель в обратном вызове
onPause()
. - В Android версии 7.0 и более поздних версиях остановите проигрыватель в обратном вызове
onStop()
.
Когда активность получает обратный вызов onDestroy()
, она должна освободить и очистить ваш плеер.