mirror of
https://github.com/androidx/media.git
synced 2025-05-21 23:56:32 +08:00
Don't select trick-play tracks by default
Issue: #6054 Issue: #474 PiperOrigin-RevId: 306504362
This commit is contained in:
parent
a99288a6fa
commit
6cff8a6ad0
@ -998,7 +998,8 @@ public final class C {
|
||||
* #ROLE_FLAG_DUB}, {@link #ROLE_FLAG_EMERGENCY}, {@link #ROLE_FLAG_CAPTION}, {@link
|
||||
* #ROLE_FLAG_SUBTITLE}, {@link #ROLE_FLAG_SIGN}, {@link #ROLE_FLAG_DESCRIBES_VIDEO}, {@link
|
||||
* #ROLE_FLAG_DESCRIBES_MUSIC_AND_SOUND}, {@link #ROLE_FLAG_ENHANCED_DIALOG_INTELLIGIBILITY},
|
||||
* {@link #ROLE_FLAG_TRANSCRIBES_DIALOG} and {@link #ROLE_FLAG_EASY_TO_READ}.
|
||||
* {@link #ROLE_FLAG_TRANSCRIBES_DIALOG}, {@link #ROLE_FLAG_EASY_TO_READ} and {@link
|
||||
* #ROLE_FLAG_TRICK_PLAY}.
|
||||
*/
|
||||
@Documented
|
||||
@Retention(RetentionPolicy.SOURCE)
|
||||
@ -1018,7 +1019,8 @@ public final class C {
|
||||
ROLE_FLAG_DESCRIBES_MUSIC_AND_SOUND,
|
||||
ROLE_FLAG_ENHANCED_DIALOG_INTELLIGIBILITY,
|
||||
ROLE_FLAG_TRANSCRIBES_DIALOG,
|
||||
ROLE_FLAG_EASY_TO_READ
|
||||
ROLE_FLAG_EASY_TO_READ,
|
||||
ROLE_FLAG_TRICK_PLAY
|
||||
})
|
||||
public @interface RoleFlags {}
|
||||
/** Indicates a main track. */
|
||||
@ -1064,6 +1066,8 @@ public final class C {
|
||||
public static final int ROLE_FLAG_TRANSCRIBES_DIALOG = 1 << 12;
|
||||
/** Indicates the track contains a text that has been edited for ease of reading. */
|
||||
public static final int ROLE_FLAG_EASY_TO_READ = 1 << 13;
|
||||
/** Indicates the track is intended for trick play. */
|
||||
public static final int ROLE_FLAG_TRICK_PLAY = 1 << 14;
|
||||
|
||||
/**
|
||||
* Converts a time in microseconds to the corresponding time in milliseconds, preserving
|
||||
|
@ -1888,6 +1888,10 @@ public class DefaultTrackSelector extends MappingTrackSelector {
|
||||
int maxVideoHeight,
|
||||
int maxVideoFrameRate,
|
||||
int maxVideoBitrate) {
|
||||
if ((format.roleFlags & C.ROLE_FLAG_TRICK_PLAY) != 0) {
|
||||
// Ignore trick-play tracks for now.
|
||||
return false;
|
||||
}
|
||||
return isSupported(formatSupport, false)
|
||||
&& ((formatSupport & requiredAdaptiveSupport) != 0)
|
||||
&& (mimeType == null || Util.areEqual(format.sampleMimeType, mimeType))
|
||||
@ -1911,9 +1915,13 @@ public class DefaultTrackSelector extends MappingTrackSelector {
|
||||
params.viewportWidth, params.viewportHeight, params.viewportOrientationMayChange);
|
||||
@Capabilities int[] trackFormatSupport = formatSupports[groupIndex];
|
||||
for (int trackIndex = 0; trackIndex < trackGroup.length; trackIndex++) {
|
||||
Format format = trackGroup.getFormat(trackIndex);
|
||||
if ((format.roleFlags & C.ROLE_FLAG_TRICK_PLAY) != 0) {
|
||||
// Ignore trick-play tracks for now.
|
||||
continue;
|
||||
}
|
||||
if (isSupported(trackFormatSupport[trackIndex],
|
||||
params.exceedRendererCapabilitiesIfNecessary)) {
|
||||
Format format = trackGroup.getFormat(trackIndex);
|
||||
boolean isWithinConstraints =
|
||||
selectedTrackIndices.contains(trackIndex)
|
||||
&& (format.width == Format.NO_VALUE || format.width <= params.maxVideoWidth)
|
||||
|
Loading…
x
Reference in New Issue
Block a user