adding controls to exit pip or switch to background audio
This commit is contained in:
parent
a11a62ede4
commit
fb6462a67f
@ -368,10 +368,43 @@ public class VideoPlayActivity extends AppCompatActivity {
|
|||||||
@RequiresApi(api = Build.VERSION_CODES.O)
|
@RequiresApi(api = Build.VERSION_CODES.O)
|
||||||
@Override
|
@Override
|
||||||
public void onPictureInPictureModeChanged (boolean isInPictureInPictureMode, Configuration newConfig) {
|
public void onPictureInPictureModeChanged (boolean isInPictureInPictureMode, Configuration newConfig) {
|
||||||
|
if (isInPictureInPictureMode) {
|
||||||
|
changedToPipMode();
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequiresApi(api = Build.VERSION_CODES.O)
|
||||||
|
public void setActions(String actionCommand) {
|
||||||
|
|
||||||
|
ArrayList<RemoteAction> actions = new ArrayList<>();
|
||||||
|
|
||||||
|
Intent actionIntent = new Intent(BACKGROUND_AUDIO);
|
||||||
|
PendingIntent pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
||||||
|
Icon icon = Icon.createWithResource(getApplicationContext(), android.R.drawable.stat_sys_speakerphone);
|
||||||
|
RemoteAction remoteAction = new RemoteAction(icon, "close pip", "from pip window custom command", pendingIntent);
|
||||||
|
actions.add(remoteAction);
|
||||||
|
|
||||||
|
actionIntent = new Intent(ACTION_STOP);
|
||||||
|
pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
||||||
|
icon = Icon.createWithResource(getApplicationContext(), com.google.android.exoplayer2.ui.R.drawable.exo_notification_stop);
|
||||||
|
remoteAction = new RemoteAction(icon, "play", "stop the media", pendingIntent);
|
||||||
|
actions.add(remoteAction);
|
||||||
|
|
||||||
|
//add custom actions to pip window
|
||||||
|
PictureInPictureParams params =
|
||||||
|
new PictureInPictureParams.Builder()
|
||||||
|
.setActions(actions)
|
||||||
|
.build();
|
||||||
|
setPictureInPictureParams(params);
|
||||||
|
|
||||||
|
}
|
||||||
|
public void changedToPipMode() {
|
||||||
FragmentManager fragmentManager = getSupportFragmentManager();
|
FragmentManager fragmentManager = getSupportFragmentManager();
|
||||||
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
||||||
|
|
||||||
if (isInPictureInPictureMode) {
|
|
||||||
videoPlayerFragment.showControls(false);
|
videoPlayerFragment.showControls(false);
|
||||||
//create custom actions
|
//create custom actions
|
||||||
setActions("");
|
setActions("");
|
||||||
@ -407,7 +440,11 @@ public class VideoPlayActivity extends AppCompatActivity {
|
|||||||
|
|
||||||
Log.v(TAG, "switched to pip ");
|
Log.v(TAG, "switched to pip ");
|
||||||
// videoPlayerFragment.useController(false);
|
// videoPlayerFragment.useController(false);
|
||||||
} else {
|
}
|
||||||
|
public void changedToNormalMode(){
|
||||||
|
FragmentManager fragmentManager = getSupportFragmentManager();
|
||||||
|
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
||||||
|
|
||||||
videoPlayerFragment.showControls(true);
|
videoPlayerFragment.showControls(true);
|
||||||
if (receiver != null) {
|
if (receiver != null) {
|
||||||
unregisterReceiver(receiver);
|
unregisterReceiver(receiver);
|
||||||
@ -417,29 +454,3 @@ public class VideoPlayActivity extends AppCompatActivity {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequiresApi(api = Build.VERSION_CODES.O)
|
|
||||||
public void setActions(String actionCommand) {
|
|
||||||
|
|
||||||
ArrayList<RemoteAction> actions = new ArrayList<>();
|
|
||||||
|
|
||||||
Intent actionIntent = new Intent(BACKGROUND_AUDIO);
|
|
||||||
PendingIntent pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
|
||||||
Icon icon = Icon.createWithResource(getApplicationContext(), android.R.drawable.stat_sys_speakerphone);
|
|
||||||
RemoteAction remoteAction = new RemoteAction(icon, "close pip", "from pip window custom command", pendingIntent);
|
|
||||||
actions.add(remoteAction);
|
|
||||||
|
|
||||||
actionIntent = new Intent(ACTION_STOP);
|
|
||||||
pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
|
||||||
icon = Icon.createWithResource(getApplicationContext(), com.google.android.exoplayer2.ui.R.drawable.exo_notification_stop);
|
|
||||||
remoteAction = new RemoteAction(icon, "play", "stop the media", pendingIntent);
|
|
||||||
actions.add(remoteAction);
|
|
||||||
|
|
||||||
//add custom actions to pip window
|
|
||||||
PictureInPictureParams params =
|
|
||||||
new PictureInPictureParams.Builder()
|
|
||||||
.setActions(actions)
|
|
||||||
.build();
|
|
||||||
setPictureInPictureParams(params);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user