אם רוצים להוסיף פקדים (הפעלה, השהיה וכו') לחלון ה-PiP, יוצרים RemoteAction
לכל אחת מהפקדים שרוצים להוסיף.
- מוסיפים קבועים לפקדי השידור:
// 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
- יוצרים רשימה של
RemoteActions
עבור הפקדים בחלון ה-PiP. - בשלב הבא מוסיפים
BroadcastReceiver
ומבטלים את ההגדרה שלonReceive()
כדי להגדיר את הפעולות של כל לחצן. משתמשים ב-DisposableEffect
כדי לרשום את המקלט ואת הפעולות מרחוק. כשהנגן מושמד, צריך לבטל את הרישום של המקלט.@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) } } }
- מעבירים רשימה של הפעולות מרחוק ל-
PictureInPictureParams.Builder
: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)
השלבים הבאים
- באפליקציה Socialite תוכלו לראות את השיטות המומלצות לשימוש ב-Compose PiP בפעולה.
- מידע נוסף זמין בהנחיות לעיצוב של מודעות ב-PiP.