mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-26 04:47:38 +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 | ||||
|         if (playbackManager.expectedTimelineSize() != simpleExoPlayer.getCurrentTimeline().getWindowCount()) return; | ||||
|         if (simpleExoPlayer.getCurrentTimeline().getWindowCount() <= currentSourceIndex) return; | ||||
|  | ||||
|         // Check if window is ready | ||||
|         Timeline.Window window = new Timeline.Window(); | ||||
| @@ -617,7 +616,7 @@ public abstract class BasePlayer implements Player.EventListener, | ||||
|     public void onPlayerStateChanged(boolean playWhenReady, int playbackState) { | ||||
|         if (DEBUG) | ||||
|             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"); | ||||
|             return; | ||||
|         } | ||||
| @@ -639,8 +638,10 @@ public abstract class BasePlayer implements Player.EventListener, | ||||
|                 changeState(playWhenReady ? STATE_PLAYING : STATE_PAUSED); | ||||
|                 break; | ||||
|             case Player.STATE_ENDED: // 4 | ||||
|                 // Ensure the current window is loaded | ||||
|                 if (simpleExoPlayer.isCurrentWindowSeekable()) { | ||||
|                 // Ensure the current window has actually ended | ||||
|                 // since single windows that are still loading may produce an ended state | ||||
|                 if (simpleExoPlayer.isCurrentWindowSeekable() && | ||||
|                         simpleExoPlayer.getCurrentPosition() >= simpleExoPlayer.getDuration()) { | ||||
|                     changeState(STATE_COMPLETED); | ||||
|                     isPrepared = false; | ||||
|                 } | ||||
| @@ -680,6 +681,7 @@ public abstract class BasePlayer implements Player.EventListener, | ||||
|         if (simpleExoPlayer == null) return; | ||||
|         if (DEBUG) Log.d(TAG, "Blocking..."); | ||||
|  | ||||
|         simpleExoPlayer.removeListener(this); | ||||
|         changeState(STATE_BLOCKED); | ||||
|  | ||||
|         wasPlaying = simpleExoPlayer.getPlayWhenReady(); | ||||
| @@ -703,6 +705,7 @@ public abstract class BasePlayer implements Player.EventListener, | ||||
|         if (DEBUG) Log.d(TAG, "Unblocking..."); | ||||
|  | ||||
|         if (getCurrentState() == STATE_BLOCKED) changeState(STATE_BUFFERING); | ||||
|         simpleExoPlayer.addListener(this); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|   | ||||
| @@ -125,7 +125,7 @@ public class PlaybackManager { | ||||
|                             break; | ||||
|                         } | ||||
|                     case UPDATE: | ||||
|                     case SHUFFLE: | ||||
|                     case REORDER: | ||||
|                         tryBlock(); | ||||
|                         resetSources(); | ||||
|                         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.PlayQueueMessage; | ||||
| 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.UpdateEvent; | ||||
|  | ||||
| @@ -29,7 +30,8 @@ public abstract class PlayQueue implements Serializable { | ||||
|  | ||||
|     public static final boolean DEBUG = true; | ||||
|  | ||||
|     private final ArrayList<PlayQueueItem> streams; | ||||
|     private ArrayList<PlayQueueItem> backup; | ||||
|     private ArrayList<PlayQueueItem> streams; | ||||
|     private final AtomicInteger queueIndex; | ||||
|  | ||||
|     private transient BehaviorSubject<PlayQueueMessage> streamsEventBroadcast; | ||||
| @@ -165,6 +167,25 @@ public abstract class PlayQueue implements Serializable { | ||||
|         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 | ||||
|     //////////////////////////////////////////////////////////////////////////*/ | ||||
|   | ||||
| @@ -19,6 +19,6 @@ public enum PlayQueueEvent { | ||||
|     UPDATE, | ||||
|  | ||||
|     // 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