mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-26 12:57:39 +00:00 
			
		
		
		
	-Added reorder event.
-Improved player blocking.
This commit is contained in:
		 John Zhen M
					John Zhen M
				
			
				
					committed by
					
						 John Zhen Mo
						John Zhen Mo
					
				
			
			
				
	
			
			
			 John Zhen Mo
						John Zhen Mo
					
				
			
						parent
						
							86c7b8522e
						
					
				
				
					commit
					6b816a11f7
				
			| @@ -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 | ||||||
|   | |||||||
| @@ -125,7 +125,7 @@ public class PlaybackManager { | |||||||
|                             break; |                             break; | ||||||
|                         } |                         } | ||||||
|                     case UPDATE: |                     case UPDATE: | ||||||
|                     case SHUFFLE: |                     case REORDER: | ||||||
|                         tryBlock(); |                         tryBlock(); | ||||||
|                         resetSources(); |                         resetSources(); | ||||||
|                         break; |                         break; | ||||||
|   | |||||||
| @@ -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 | ||||||
|     //////////////////////////////////////////////////////////////////////////*/ |     //////////////////////////////////////////////////////////////////////////*/ | ||||||
|   | |||||||
| @@ -19,6 +19,6 @@ public enum PlayQueueEvent { | |||||||
|     UPDATE, |     UPDATE, | ||||||
|  |  | ||||||
|     // send when queue is shuffled |     // send when queue is shuffled | ||||||
|     SHUFFLE |     REORDER | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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; | ||||||
|  |     } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user