mirror of
https://github.com/TeamNewPipe/NewPipe
synced 2025-01-25 00:16:56 +00:00
Merge pull request #5457 from Redirion/exo123
Update to ExoPlayer 2.12.3
This commit is contained in:
commit
86381696f4
@ -96,7 +96,7 @@ ext {
|
|||||||
checkstyleVersion = '8.38'
|
checkstyleVersion = '8.38'
|
||||||
stethoVersion = '1.5.1'
|
stethoVersion = '1.5.1'
|
||||||
leakCanaryVersion = '2.5'
|
leakCanaryVersion = '2.5'
|
||||||
exoPlayerVersion = '2.11.8'
|
exoPlayerVersion = '2.12.3'
|
||||||
androidxLifecycleVersion = '2.2.0'
|
androidxLifecycleVersion = '2.2.0'
|
||||||
androidxRoomVersion = '2.3.0-alpha03'
|
androidxRoomVersion = '2.3.0-alpha03'
|
||||||
groupieVersion = '2.8.1'
|
groupieVersion = '2.8.1'
|
||||||
|
@ -601,7 +601,8 @@ public final class Player implements
|
|||||||
final PlaybackParameters savedParameters = retrievePlaybackParametersFromPrefs(this);
|
final PlaybackParameters savedParameters = retrievePlaybackParametersFromPrefs(this);
|
||||||
final float playbackSpeed = savedParameters.speed;
|
final float playbackSpeed = savedParameters.speed;
|
||||||
final float playbackPitch = savedParameters.pitch;
|
final float playbackPitch = savedParameters.pitch;
|
||||||
final boolean playbackSkipSilence = savedParameters.skipSilence;
|
final boolean playbackSkipSilence = getPrefs().getBoolean(getContext().getString(
|
||||||
|
R.string.playback_skip_silence_key), getPlaybackSkipSilence());
|
||||||
|
|
||||||
final boolean samePlayQueue = playQueue != null && playQueue.equals(newQueue);
|
final boolean samePlayQueue = playQueue != null && playQueue.equals(newQueue);
|
||||||
final int repeatMode = intent.getIntExtra(REPEAT_MODE, getRepeatMode());
|
final int repeatMode = intent.getIntExtra(REPEAT_MODE, getRepeatMode());
|
||||||
@ -1516,7 +1517,8 @@ public final class Player implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean getPlaybackSkipSilence() {
|
public boolean getPlaybackSkipSilence() {
|
||||||
return getPlaybackParameters().skipSilence;
|
return !exoPlayerIsNull() && simpleExoPlayer.getAudioComponent() != null
|
||||||
|
&& simpleExoPlayer.getAudioComponent().getSkipSilenceEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
public PlaybackParameters getPlaybackParameters() {
|
public PlaybackParameters getPlaybackParameters() {
|
||||||
@ -1541,7 +1543,10 @@ public final class Player implements
|
|||||||
|
|
||||||
savePlaybackParametersToPrefs(this, roundedSpeed, roundedPitch, skipSilence);
|
savePlaybackParametersToPrefs(this, roundedSpeed, roundedPitch, skipSilence);
|
||||||
simpleExoPlayer.setPlaybackParameters(
|
simpleExoPlayer.setPlaybackParameters(
|
||||||
new PlaybackParameters(roundedSpeed, roundedPitch, skipSilence));
|
new PlaybackParameters(roundedSpeed, roundedPitch));
|
||||||
|
if (simpleExoPlayer.getAudioComponent() != null) {
|
||||||
|
simpleExoPlayer.getAudioComponent().setSkipSilenceEnabled(skipSilence);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
//endregion
|
//endregion
|
||||||
|
|
||||||
@ -2417,6 +2422,7 @@ public final class Player implements
|
|||||||
case ExoPlaybackException.TYPE_OUT_OF_MEMORY:
|
case ExoPlaybackException.TYPE_OUT_OF_MEMORY:
|
||||||
case ExoPlaybackException.TYPE_REMOTE:
|
case ExoPlaybackException.TYPE_REMOTE:
|
||||||
case ExoPlaybackException.TYPE_RENDERER:
|
case ExoPlaybackException.TYPE_RENDERER:
|
||||||
|
case ExoPlaybackException.TYPE_TIMEOUT:
|
||||||
default:
|
default:
|
||||||
showUnrecoverableError(error);
|
showUnrecoverableError(error);
|
||||||
onPlaybackShutdown();
|
onPlaybackShutdown();
|
||||||
@ -3439,7 +3445,7 @@ public final class Player implements
|
|||||||
final List<String> availableLanguages = new ArrayList<>(textTracks.length);
|
final List<String> availableLanguages = new ArrayList<>(textTracks.length);
|
||||||
for (int i = 0; i < textTracks.length; i++) {
|
for (int i = 0; i < textTracks.length; i++) {
|
||||||
final TrackGroup textTrack = textTracks.get(i);
|
final TrackGroup textTrack = textTracks.get(i);
|
||||||
if (textTrack.length > 0 && textTrack.getFormat(0) != null) {
|
if (textTrack.length > 0) {
|
||||||
availableLanguages.add(textTrack.getFormat(0).language);
|
availableLanguages.add(textTrack.getFormat(0).language);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -80,12 +80,14 @@ public class LoadController implements LoadControl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean shouldContinueLoading(final long bufferedDurationUs,
|
public boolean shouldContinueLoading(final long playbackPositionUs,
|
||||||
|
final long bufferedDurationUs,
|
||||||
final float playbackSpeed) {
|
final float playbackSpeed) {
|
||||||
if (!preloadingEnabled) {
|
if (!preloadingEnabled) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return internalLoadControl.shouldContinueLoading(bufferedDurationUs, playbackSpeed);
|
return internalLoadControl.shouldContinueLoading(
|
||||||
|
playbackPositionUs, bufferedDurationUs, playbackSpeed);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -495,9 +495,7 @@ public final class PlayerHelper {
|
|||||||
R.string.playback_speed_key), player.getPlaybackSpeed());
|
R.string.playback_speed_key), player.getPlaybackSpeed());
|
||||||
final float pitch = player.getPrefs().getFloat(player.getContext().getString(
|
final float pitch = player.getPrefs().getFloat(player.getContext().getString(
|
||||||
R.string.playback_pitch_key), player.getPlaybackPitch());
|
R.string.playback_pitch_key), player.getPlaybackPitch());
|
||||||
final boolean skipSilence = player.getPrefs().getBoolean(player.getContext().getString(
|
return new PlaybackParameters(speed, pitch);
|
||||||
R.string.playback_skip_silence_key), player.getPlaybackSkipSilence());
|
|
||||||
return new PlaybackParameters(speed, pitch, skipSilence);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void savePlaybackParametersToPrefs(final Player player,
|
public static void savePlaybackParametersToPrefs(final Player player,
|
||||||
|
@ -5,6 +5,7 @@ import android.util.Log;
|
|||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
|
import com.google.android.exoplayer2.MediaItem;
|
||||||
import com.google.android.exoplayer2.source.BaseMediaSource;
|
import com.google.android.exoplayer2.source.BaseMediaSource;
|
||||||
import com.google.android.exoplayer2.source.MediaPeriod;
|
import com.google.android.exoplayer2.source.MediaPeriod;
|
||||||
import com.google.android.exoplayer2.upstream.Allocator;
|
import com.google.android.exoplayer2.upstream.Allocator;
|
||||||
@ -54,6 +55,14 @@ public class FailedMediaSource extends BaseMediaSource implements ManagedMediaSo
|
|||||||
return System.currentTimeMillis() >= retryTimestamp;
|
return System.currentTimeMillis() >= retryTimestamp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the {@link MediaItem} whose media is provided by the source.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public MediaItem getMediaItem() {
|
||||||
|
return MediaItem.fromUri(playQueueItem.getUrl());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void maybeThrowSourceInfoRefreshError() throws IOException {
|
public void maybeThrowSourceInfoRefreshError() throws IOException {
|
||||||
throw new IOException(error);
|
throw new IOException(error);
|
||||||
|
@ -5,6 +5,8 @@ import android.os.Handler;
|
|||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
|
import com.google.android.exoplayer2.MediaItem;
|
||||||
|
import com.google.android.exoplayer2.drm.DrmSessionEventListener;
|
||||||
import com.google.android.exoplayer2.source.MediaPeriod;
|
import com.google.android.exoplayer2.source.MediaPeriod;
|
||||||
import com.google.android.exoplayer2.source.MediaSource;
|
import com.google.android.exoplayer2.source.MediaSource;
|
||||||
import com.google.android.exoplayer2.source.MediaSourceEventListener;
|
import com.google.android.exoplayer2.source.MediaSourceEventListener;
|
||||||
@ -83,6 +85,38 @@ public class LoadedMediaSource implements ManagedMediaSource {
|
|||||||
source.removeEventListener(eventListener);
|
source.removeEventListener(eventListener);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a {@link DrmSessionEventListener} to the list of listeners which are notified of DRM
|
||||||
|
* events for this media source.
|
||||||
|
*
|
||||||
|
* @param handler A handler on the which listener events will be posted.
|
||||||
|
* @param eventListener The listener to be added.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void addDrmEventListener(final Handler handler,
|
||||||
|
final DrmSessionEventListener eventListener) {
|
||||||
|
source.addDrmEventListener(handler, eventListener);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes a {@link DrmSessionEventListener} from the list of listeners which are notified of
|
||||||
|
* DRM events for this media source.
|
||||||
|
*
|
||||||
|
* @param eventListener The listener to be removed.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void removeDrmEventListener(final DrmSessionEventListener eventListener) {
|
||||||
|
source.removeDrmEventListener(eventListener);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the {@link MediaItem} whose media is provided by the source.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public MediaItem getMediaItem() {
|
||||||
|
return source.getMediaItem();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean shouldBeReplacedWith(@NonNull final PlayQueueItem newIdentity,
|
public boolean shouldBeReplacedWith(@NonNull final PlayQueueItem newIdentity,
|
||||||
final boolean isInterruptable) {
|
final boolean isInterruptable) {
|
||||||
|
@ -3,6 +3,7 @@ package org.schabi.newpipe.player.mediasource;
|
|||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
|
import com.google.android.exoplayer2.MediaItem;
|
||||||
import com.google.android.exoplayer2.source.BaseMediaSource;
|
import com.google.android.exoplayer2.source.BaseMediaSource;
|
||||||
import com.google.android.exoplayer2.source.MediaPeriod;
|
import com.google.android.exoplayer2.source.MediaPeriod;
|
||||||
import com.google.android.exoplayer2.upstream.Allocator;
|
import com.google.android.exoplayer2.upstream.Allocator;
|
||||||
@ -11,6 +12,14 @@ import com.google.android.exoplayer2.upstream.TransferListener;
|
|||||||
import org.schabi.newpipe.player.playqueue.PlayQueueItem;
|
import org.schabi.newpipe.player.playqueue.PlayQueueItem;
|
||||||
|
|
||||||
public class PlaceholderMediaSource extends BaseMediaSource implements ManagedMediaSource {
|
public class PlaceholderMediaSource extends BaseMediaSource implements ManagedMediaSource {
|
||||||
|
/**
|
||||||
|
* Returns the {@link MediaItem} whose media is provided by the source.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public MediaItem getMediaItem() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
// Do nothing, so this will stall the playback
|
// Do nothing, so this will stall the playback
|
||||||
@Override
|
@Override
|
||||||
public void maybeThrowSourceInfoRefreshError() { }
|
public void maybeThrowSourceInfoRefreshError() { }
|
||||||
|
Loading…
Reference in New Issue
Block a user