Wenn du deinem PiP-Fenster Steuerelemente wie „Wiedergabe“ oder „Pause“ hinzufügen möchtest, erstelle für jedes Steuerelement eine RemoteAction
.
- Füge Konstanten für deine Übertragungssteuerungen hinzu:
// Constant for broadcast receiver const val ACTION_BROADCAST_CONTROL = "broadcast_control" // Intent extras for broadcast controls from Picture-in-Picture mode. const val EXTRA_CONTROL_TYPE = "control_type" const val EXTRA_CONTROL_PLAY = 1 const val EXTRA_CONTROL_PAUSE = 2
- Erstelle eine Liste mit
RemoteActions
für die Steuerelemente im PiP-Fenster. - Fügen Sie als Nächstes ein
BroadcastReceiver
hinzu und überschreiben SieonReceive()
, um die Aktionen der einzelnen Schaltflächen festzulegen. Verwenden SieDisposableEffect
, um den Empfänger und die Remote-Aktionen zu registrieren. Wenn der Player entsorgt wird, melde den Empfänger ab.@RequiresApi(Build.VERSION_CODES.O) @Composable fun PlayerBroadcastReceiver(player: Player?) { val isInPipMode = rememberIsInPipMode() if (!isInPipMode || player == null) { // Broadcast receiver is only used if app is in PiP mode and player is non null return } val context = LocalContext.current DisposableEffect(player) { val broadcastReceiver: BroadcastReceiver = object : BroadcastReceiver() { override fun onReceive(context: Context?, intent: Intent?) { if ((intent == null) || (intent.action != ACTION_BROADCAST_CONTROL)) { return } when (intent.getIntExtra(EXTRA_CONTROL_TYPE, 0)) { EXTRA_CONTROL_PAUSE -> player.pause() EXTRA_CONTROL_PLAY -> player.play() } } } ContextCompat.registerReceiver( context, broadcastReceiver, IntentFilter(ACTION_BROADCAST_CONTROL), ContextCompat.RECEIVER_NOT_EXPORTED ) onDispose { context.unregisterReceiver(broadcastReceiver) } } }
- Geben Sie eine Liste Ihrer Remoteaktionen an die
PictureInPictureParams.Builder
weiter:val context = LocalContext.current val pipModifier = modifier.onGloballyPositioned { layoutCoordinates -> val builder = PictureInPictureParams.Builder() builder.setActions( listOfRemoteActions() ) if (shouldEnterPipMode && player != null && player.videoSize != VideoSize.UNKNOWN) { val sourceRect = layoutCoordinates.boundsInWindow().toAndroidRectF().toRect() builder.setSourceRectHint(sourceRect) builder.setAspectRatio( Rational(player.videoSize.width, player.videoSize.height) ) } if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.S) { builder.setAutoEnterEnabled(shouldEnterPipMode) } context.findActivity().setPictureInPictureParams(builder.build()) } VideoPlayer(modifier = pipModifier)
Nächste Schritte
- In der App Socialite können Sie sich die Best Practices für Compose PiP in Aktion ansehen.
- Weitere Informationen finden Sie in den Designrichtlinien für Picture-in-Picture-Videos.