-Added reorder event.

-Improved player blocking.
This commit is contained in:
John Zhen M 2017-09-15 21:28:56 -07:00 committed by John Zhen Mo
parent 86c7b8522e
commit 6b816a11f7
5 changed files with 49 additions and 7 deletions

View file

@ -560,7 +560,6 @@ public abstract class BasePlayer implements Player.EventListener,
// Check timeline is up-to-date and has window // Check timeline is up-to-date and has window
if (playbackManager.expectedTimelineSize() != simpleExoPlayer.getCurrentTimeline().getWindowCount()) return; if (playbackManager.expectedTimelineSize() != simpleExoPlayer.getCurrentTimeline().getWindowCount()) return;
if (simpleExoPlayer.getCurrentTimeline().getWindowCount() <= currentSourceIndex) return;
// Check if window is ready // Check if window is ready
Timeline.Window window = new Timeline.Window(); Timeline.Window window = new Timeline.Window();
@ -617,7 +616,7 @@ public abstract class BasePlayer implements Player.EventListener,
public void onPlayerStateChanged(boolean playWhenReady, int playbackState) { public void onPlayerStateChanged(boolean playWhenReady, int playbackState) {
if (DEBUG) if (DEBUG)
Log.d(TAG, "onPlayerStateChanged() called with: playWhenReady = [" + playWhenReady + "], playbackState = [" + playbackState + "]"); Log.d(TAG, "onPlayerStateChanged() called with: playWhenReady = [" + playWhenReady + "], playbackState = [" + playbackState + "]");
if (getCurrentState() == STATE_PAUSED_SEEK || getCurrentState() == STATE_BLOCKED) { if (getCurrentState() == STATE_PAUSED_SEEK) {
if (DEBUG) Log.d(TAG, "onPlayerStateChanged() is currently blocked"); if (DEBUG) Log.d(TAG, "onPlayerStateChanged() is currently blocked");
return; return;
} }
@ -639,8 +638,10 @@ public abstract class BasePlayer implements Player.EventListener,
changeState(playWhenReady ? STATE_PLAYING : STATE_PAUSED); changeState(playWhenReady ? STATE_PLAYING : STATE_PAUSED);
break; break;
case Player.STATE_ENDED: // 4 case Player.STATE_ENDED: // 4
// Ensure the current window is loaded // Ensure the current window has actually ended
if (simpleExoPlayer.isCurrentWindowSeekable()) { // since single windows that are still loading may produce an ended state
if (simpleExoPlayer.isCurrentWindowSeekable() &&
simpleExoPlayer.getCurrentPosition() >= simpleExoPlayer.getDuration()) {
changeState(STATE_COMPLETED); changeState(STATE_COMPLETED);
isPrepared = false; isPrepared = false;
} }
@ -680,6 +681,7 @@ public abstract class BasePlayer implements Player.EventListener,
if (simpleExoPlayer == null) return; if (simpleExoPlayer == null) return;
if (DEBUG) Log.d(TAG, "Blocking..."); if (DEBUG) Log.d(TAG, "Blocking...");
simpleExoPlayer.removeListener(this);
changeState(STATE_BLOCKED); changeState(STATE_BLOCKED);
wasPlaying = simpleExoPlayer.getPlayWhenReady(); wasPlaying = simpleExoPlayer.getPlayWhenReady();
@ -703,6 +705,7 @@ public abstract class BasePlayer implements Player.EventListener,
if (DEBUG) Log.d(TAG, "Unblocking..."); if (DEBUG) Log.d(TAG, "Unblocking...");
if (getCurrentState() == STATE_BLOCKED) changeState(STATE_BUFFERING); if (getCurrentState() == STATE_BLOCKED) changeState(STATE_BUFFERING);
simpleExoPlayer.addListener(this);
} }
@Override @Override

View file

@ -125,7 +125,7 @@ public class PlaybackManager {
break; break;
} }
case UPDATE: case UPDATE:
case SHUFFLE: case REORDER:
tryBlock(); tryBlock();
resetSources(); resetSources();
break; break;

View file

@ -9,6 +9,7 @@ import org.schabi.newpipe.playlist.events.AppendEvent;
import org.schabi.newpipe.playlist.events.InitEvent; import org.schabi.newpipe.playlist.events.InitEvent;
import org.schabi.newpipe.playlist.events.PlayQueueMessage; import org.schabi.newpipe.playlist.events.PlayQueueMessage;
import org.schabi.newpipe.playlist.events.RemoveEvent; import org.schabi.newpipe.playlist.events.RemoveEvent;
import org.schabi.newpipe.playlist.events.ReorderEvent;
import org.schabi.newpipe.playlist.events.SelectEvent; import org.schabi.newpipe.playlist.events.SelectEvent;
import org.schabi.newpipe.playlist.events.UpdateEvent; import org.schabi.newpipe.playlist.events.UpdateEvent;
@ -29,7 +30,8 @@ public abstract class PlayQueue implements Serializable {
public static final boolean DEBUG = true; public static final boolean DEBUG = true;
private final ArrayList<PlayQueueItem> streams; private ArrayList<PlayQueueItem> backup;
private ArrayList<PlayQueueItem> streams;
private final AtomicInteger queueIndex; private final AtomicInteger queueIndex;
private transient BehaviorSubject<PlayQueueMessage> streamsEventBroadcast; private transient BehaviorSubject<PlayQueueMessage> streamsEventBroadcast;
@ -165,6 +167,25 @@ public abstract class PlayQueue implements Serializable {
broadcast(new RemoveEvent(index, isCurrent)); broadcast(new RemoveEvent(index, isCurrent));
} }
public synchronized void shuffle() {
backup = new ArrayList<>(streams);
final PlayQueueItem current = getCurrent();
Collections.shuffle(streams);
queueIndex.set(streams.indexOf(current));
broadcast(new ReorderEvent(true));
}
public synchronized void unshuffle() {
if (backup == null) return;
final PlayQueueItem current = getCurrent();
streams.clear();
streams = backup;
queueIndex.set(streams.indexOf(current));
broadcast(new ReorderEvent(false));
}
/*////////////////////////////////////////////////////////////////////////// /*//////////////////////////////////////////////////////////////////////////
// Rx Broadcast // Rx Broadcast
//////////////////////////////////////////////////////////////////////////*/ //////////////////////////////////////////////////////////////////////////*/

View file

@ -19,6 +19,6 @@ public enum PlayQueueEvent {
UPDATE, UPDATE,
// send when queue is shuffled // send when queue is shuffled
SHUFFLE REORDER
} }

View file

@ -0,0 +1,18 @@
package org.schabi.newpipe.playlist.events;
public class ReorderEvent implements PlayQueueMessage {
final private boolean randomize;
@Override
public PlayQueueEvent type() {
return PlayQueueEvent.REORDER;
}
public ReorderEvent(final boolean randomize) {
this.randomize = randomize;
}
public boolean isRandomize() {
return randomize;
}
}