Improve dialog of streams for external players and fix use of the wrong codec in the list of available streams in it after a codec change in Video and Audio settings
The VideoDetailFragment will now get video streams dynamically instead of storing them as a field, so the good codec can be chosen by ListHelper. To select a stream to play, user has now to select the quality in the list of available qualities and then press the new OK button in the alert dialog.
This commit is contained in:
parent
210834fbe9
commit
7d6bf4b0ca
1 changed files with 22 additions and 14 deletions
|
@ -188,7 +188,6 @@ public final class VideoDetailFragment
|
||||||
@Nullable
|
@Nullable
|
||||||
private Disposable positionSubscriber = null;
|
private Disposable positionSubscriber = null;
|
||||||
|
|
||||||
private List<VideoStream> videoStreamsForExternalPlayers;
|
|
||||||
private BottomSheetBehavior<FrameLayout> bottomSheetBehavior;
|
private BottomSheetBehavior<FrameLayout> bottomSheetBehavior;
|
||||||
private BroadcastReceiver broadcastReceiver;
|
private BroadcastReceiver broadcastReceiver;
|
||||||
|
|
||||||
|
@ -1615,13 +1614,6 @@ public final class VideoDetailFragment
|
||||||
binding.detailToggleSecondaryControlsView.setVisibility(View.VISIBLE);
|
binding.detailToggleSecondaryControlsView.setVisibility(View.VISIBLE);
|
||||||
binding.detailSecondaryControlPanel.setVisibility(View.GONE);
|
binding.detailSecondaryControlPanel.setVisibility(View.GONE);
|
||||||
|
|
||||||
final List<VideoStream> videoStreams = removeNonUrlAndTorrentStreams(
|
|
||||||
new ArrayList<>(currentInfo.getVideoStreams()));
|
|
||||||
final List<VideoStream> videoOnlyStreams = removeNonUrlAndTorrentStreams(
|
|
||||||
new ArrayList<>(currentInfo.getVideoOnlyStreams()));
|
|
||||||
videoStreamsForExternalPlayers = ListHelper.getSortedStreamVideosList(activity,
|
|
||||||
videoStreams, videoOnlyStreams, false, false);
|
|
||||||
|
|
||||||
updateProgressInfo(info);
|
updateProgressInfo(info);
|
||||||
initThumbnailViews(info);
|
initThumbnailViews(info);
|
||||||
showMetaInfoInTextView(info.getMetaInfo(), binding.detailMetaInfoTextView,
|
showMetaInfoInTextView(info.getMetaInfo(), binding.detailMetaInfoTextView,
|
||||||
|
@ -2155,13 +2147,21 @@ public final class VideoDetailFragment
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final List<VideoStream> videoStreams = removeNonUrlAndTorrentStreams(
|
||||||
|
new ArrayList<>(currentInfo.getVideoStreams()));
|
||||||
|
final List<VideoStream> videoOnlyStreams = removeNonUrlAndTorrentStreams(
|
||||||
|
new ArrayList<>(currentInfo.getVideoOnlyStreams()));
|
||||||
|
|
||||||
final AlertDialog.Builder builder = new AlertDialog.Builder(activity);
|
final AlertDialog.Builder builder = new AlertDialog.Builder(activity);
|
||||||
builder.setTitle(R.string.select_quality_external_players);
|
builder.setTitle(R.string.select_quality_external_players);
|
||||||
builder.setNegativeButton(android.R.string.cancel, null);
|
|
||||||
builder.setNeutralButton(R.string.open_in_browser, (dialog, i) ->
|
builder.setNeutralButton(R.string.open_in_browser, (dialog, i) ->
|
||||||
ShareUtils.openUrlInBrowser(requireActivity(), url));
|
ShareUtils.openUrlInBrowser(requireActivity(), url));
|
||||||
|
final List<VideoStream> videoStreamsForExternalPlayers =
|
||||||
|
ListHelper.getSortedStreamVideosList(activity, videoStreams, videoOnlyStreams,
|
||||||
|
false, false);
|
||||||
if (videoStreamsForExternalPlayers.isEmpty()) {
|
if (videoStreamsForExternalPlayers.isEmpty()) {
|
||||||
builder.setMessage(R.string.no_video_streams_available_for_external_players);
|
builder.setMessage(R.string.no_video_streams_available_for_external_players);
|
||||||
|
builder.setPositiveButton(R.string.ok, null);
|
||||||
} else {
|
} else {
|
||||||
final int selectedVideoStreamIndexForExternalPlayers =
|
final int selectedVideoStreamIndexForExternalPlayers =
|
||||||
ListHelper.getDefaultResolutionIndex(activity, videoStreamsForExternalPlayers);
|
ListHelper.getDefaultResolutionIndex(activity, videoStreamsForExternalPlayers);
|
||||||
|
@ -2173,11 +2173,19 @@ public final class VideoDetailFragment
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.setSingleChoiceItems(resolutions, selectedVideoStreamIndexForExternalPlayers,
|
builder.setSingleChoiceItems(resolutions, selectedVideoStreamIndexForExternalPlayers,
|
||||||
(dialog, i) -> {
|
null);
|
||||||
dialog.dismiss();
|
builder.setNegativeButton(R.string.cancel, null);
|
||||||
startOnExternalPlayer(activity, currentInfo,
|
builder.setPositiveButton(R.string.ok, (dialog, i) -> {
|
||||||
videoStreamsForExternalPlayers.get(i));
|
final int index = ((AlertDialog) dialog).getListView().getCheckedItemPosition();
|
||||||
});
|
// We don't have to manage the index validity because if there is no stream
|
||||||
|
// available for external players, this code will be not executed and if there is
|
||||||
|
// no stream which matches the default resolution, 0 is returned by
|
||||||
|
// ListHelper.getDefaultResolutionIndex.
|
||||||
|
// The index cannot be outside the bounds of the list as its always between 0 and
|
||||||
|
// the list size - 1, .
|
||||||
|
startOnExternalPlayer(activity, currentInfo,
|
||||||
|
videoStreamsForExternalPlayers.get(index));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
builder.show();
|
builder.show();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue