mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-26 12:57:39 +00:00 
			
		
		
		
	Use StreamTypeUtil where possible and add isAudio and isVideo to this utility class
This commit is contained in:
		| @@ -12,8 +12,7 @@ import org.schabi.newpipe.database.BasicDAO | ||||
| import org.schabi.newpipe.database.stream.model.StreamEntity | ||||
| import org.schabi.newpipe.database.stream.model.StreamEntity.Companion.STREAM_ID | ||||
| import org.schabi.newpipe.extractor.stream.StreamType | ||||
| import org.schabi.newpipe.extractor.stream.StreamType.AUDIO_LIVE_STREAM | ||||
| import org.schabi.newpipe.extractor.stream.StreamType.LIVE_STREAM | ||||
| import org.schabi.newpipe.util.StreamTypeUtil | ||||
| import java.time.OffsetDateTime | ||||
|  | ||||
| @Dao | ||||
| @@ -91,8 +90,7 @@ abstract class StreamDAO : BasicDAO<StreamEntity> { | ||||
|             ?: throw IllegalStateException("Stream cannot be null just after insertion.") | ||||
|         newerStream.uid = existentMinimalStream.uid | ||||
|  | ||||
|         val isNewerStreamLive = newerStream.streamType == AUDIO_LIVE_STREAM || newerStream.streamType == LIVE_STREAM | ||||
|         if (!isNewerStreamLive) { | ||||
|         if (!StreamTypeUtil.isLiveStream(newerStream.streamType)) { | ||||
|  | ||||
|             // Use the existent upload date if the newer stream does not have a better precision | ||||
|             // (i.e. is an approximation). This is done to prevent unnecessary changes. | ||||
|   | ||||
| @@ -24,6 +24,7 @@ import org.schabi.newpipe.extractor.InfoItem; | ||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItem; | ||||
| import org.schabi.newpipe.extractor.stream.StreamType; | ||||
| import org.schabi.newpipe.player.helper.PlayerHolder; | ||||
| import org.schabi.newpipe.util.StreamTypeUtil; | ||||
| import org.schabi.newpipe.util.external_communication.KoreUtils; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| @@ -269,8 +270,7 @@ public final class InfoItemDialog { | ||||
|          */ | ||||
|         public Builder addStartHereEntries() { | ||||
|             addEntry(StreamDialogDefaultEntry.START_HERE_ON_BACKGROUND); | ||||
|             if (infoItem.getStreamType() != StreamType.AUDIO_STREAM | ||||
|                     && infoItem.getStreamType() != StreamType.AUDIO_LIVE_STREAM) { | ||||
|             if (!StreamTypeUtil.isAudio(infoItem.getStreamType())) { | ||||
|                 addEntry(StreamDialogDefaultEntry.START_HERE_ON_POPUP); | ||||
|             } | ||||
|             return this; | ||||
| @@ -285,9 +285,7 @@ public final class InfoItemDialog { | ||||
|             final boolean isWatchHistoryEnabled = PreferenceManager | ||||
|                     .getDefaultSharedPreferences(context) | ||||
|                     .getBoolean(context.getString(R.string.enable_watch_history_key), false); | ||||
|             if (isWatchHistoryEnabled | ||||
|                     && infoItem.getStreamType() != StreamType.LIVE_STREAM | ||||
|                     && infoItem.getStreamType() != StreamType.AUDIO_LIVE_STREAM) { | ||||
|             if (isWatchHistoryEnabled && !StreamTypeUtil.isLiveStream(infoItem.getStreamType())) { | ||||
|                 addEntry(StreamDialogDefaultEntry.MARK_AS_WATCHED); | ||||
|             } | ||||
|             return this; | ||||
|   | ||||
| @@ -11,12 +11,12 @@ import org.schabi.newpipe.R; | ||||
| import org.schabi.newpipe.database.stream.model.StreamStateEntity; | ||||
| import org.schabi.newpipe.extractor.InfoItem; | ||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItem; | ||||
| import org.schabi.newpipe.extractor.stream.StreamType; | ||||
| import org.schabi.newpipe.info_list.InfoItemBuilder; | ||||
| import org.schabi.newpipe.ktx.ViewUtils; | ||||
| import org.schabi.newpipe.local.history.HistoryRecordManager; | ||||
| import org.schabi.newpipe.util.PicassoHelper; | ||||
| import org.schabi.newpipe.util.Localization; | ||||
| import org.schabi.newpipe.util.StreamTypeUtil; | ||||
| import org.schabi.newpipe.views.AnimatedProgressBar; | ||||
|  | ||||
| import java.util.concurrent.TimeUnit; | ||||
| @@ -70,8 +70,7 @@ public class StreamMiniInfoItemHolder extends InfoItemHolder { | ||||
|             } else { | ||||
|                 itemProgressView.setVisibility(View.GONE); | ||||
|             } | ||||
|         } else if (item.getStreamType() == StreamType.LIVE_STREAM | ||||
|                 || item.getStreamType() == StreamType.AUDIO_LIVE_STREAM) { | ||||
|         } else if (StreamTypeUtil.isLiveStream(item.getStreamType())) { | ||||
|             itemDurationView.setText(R.string.duration_live); | ||||
|             itemDurationView.setBackgroundColor(ContextCompat.getColor(itemBuilder.getContext(), | ||||
|                     R.color.live_duration_background_color)); | ||||
| @@ -115,8 +114,7 @@ public class StreamMiniInfoItemHolder extends InfoItemHolder { | ||||
|         final StreamStateEntity state | ||||
|                 = historyRecordManager.loadStreamState(infoItem).blockingGet()[0]; | ||||
|         if (state != null && item.getDuration() > 0 | ||||
|                 && item.getStreamType() != StreamType.LIVE_STREAM | ||||
|                 && item.getStreamType() != StreamType.AUDIO_LIVE_STREAM) { | ||||
|                 && !StreamTypeUtil.isLiveStream(item.getStreamType())) { | ||||
|             itemProgressView.setMax((int) item.getDuration()); | ||||
|             if (itemProgressView.getVisibility() == View.VISIBLE) { | ||||
|                 itemProgressView.setProgressAnimated((int) TimeUnit.MILLISECONDS | ||||
|   | ||||
| @@ -4234,10 +4234,7 @@ public final class Player implements | ||||
|         if (playQueueManagerReloadingNeeded(sourceType, info, getVideoRendererIndex())) { | ||||
|             reloadPlayQueueManager(); | ||||
|         } else { | ||||
|             final StreamType streamType = info.getStreamType(); | ||||
|             if (streamType == StreamType.AUDIO_STREAM | ||||
|                     || streamType == StreamType.AUDIO_LIVE_STREAM | ||||
|                     || streamType == StreamType.POST_LIVE_AUDIO_STREAM) { | ||||
|             if (StreamTypeUtil.isAudio(info.getStreamType())) { | ||||
|                 // Nothing to do more than setting the recovery position | ||||
|                 setRecovery(); | ||||
|                 return; | ||||
| @@ -4296,21 +4293,17 @@ public final class Player implements | ||||
|                                                     @NonNull final StreamInfo streamInfo, | ||||
|                                                     final int videoRendererIndex) { | ||||
|         final StreamType streamType = streamInfo.getStreamType(); | ||||
|         final boolean isStreamTypeAudio = StreamTypeUtil.isAudio(streamType); | ||||
|  | ||||
|         if (videoRendererIndex == RENDERER_UNAVAILABLE && streamType != StreamType.AUDIO_STREAM | ||||
|                 && streamType != StreamType.AUDIO_LIVE_STREAM | ||||
|                 && streamType != StreamType.POST_LIVE_AUDIO_STREAM) { | ||||
|         if (videoRendererIndex == RENDERER_UNAVAILABLE && !isStreamTypeAudio) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         // The content is an audio stream, an audio live stream, or a live stream with a live | ||||
|         // source: it's not needed to reload the play queue manager because the stream source will | ||||
|         // be the same | ||||
|         if ((streamType == StreamType.AUDIO_STREAM | ||||
|                 || streamType == StreamType.POST_LIVE_AUDIO_STREAM | ||||
|                 || streamType == StreamType.AUDIO_LIVE_STREAM) | ||||
|                 || (streamType == StreamType.LIVE_STREAM | ||||
|                         && sourceType == SourceType.LIVE_STREAM)) { | ||||
|         if (isStreamTypeAudio || (streamType == StreamType.LIVE_STREAM | ||||
|                 && sourceType == SourceType.LIVE_STREAM)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
| @@ -4324,9 +4317,7 @@ public final class Player implements | ||||
|                     && isNullOrEmpty(streamInfo.getAudioStreams()))) { | ||||
|             // It's not needed to reload the play queue manager only if the content's stream type | ||||
|             // is a video stream, a live stream or an ended live stream | ||||
|             return streamType != StreamType.VIDEO_STREAM | ||||
|                     && streamType != StreamType.LIVE_STREAM | ||||
|                     && streamType != StreamType.POST_LIVE_STREAM; | ||||
|             return !StreamTypeUtil.isVideo(streamType); | ||||
|         } | ||||
|  | ||||
|         // Other cases: the play queue manager reload is needed | ||||
|   | ||||
| @@ -1,7 +1,5 @@ | ||||
| package org.schabi.newpipe.util; | ||||
|  | ||||
| import static org.schabi.newpipe.extractor.stream.StreamType.AUDIO_LIVE_STREAM; | ||||
| import static org.schabi.newpipe.extractor.stream.StreamType.LIVE_STREAM; | ||||
| import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty; | ||||
|  | ||||
| import android.content.Context; | ||||
| @@ -49,8 +47,8 @@ public final class SparseItemUtil { | ||||
|     public static void fetchItemInfoIfSparse(@NonNull final Context context, | ||||
|                                              @NonNull final StreamInfoItem item, | ||||
|                                              @NonNull final Consumer<SinglePlayQueue> callback) { | ||||
|         if (((item.getStreamType() == LIVE_STREAM || item.getStreamType() == AUDIO_LIVE_STREAM) | ||||
|                 || item.getDuration() >= 0) && !isNullOrEmpty(item.getUploaderUrl())) { | ||||
|         if ((StreamTypeUtil.isLiveStream(item.getStreamType()) || item.getDuration() >= 0) | ||||
|                 && !isNullOrEmpty(item.getUploaderUrl())) { | ||||
|             // if the duration is >= 0 (provided that the item is not a livestream) and there is an | ||||
|             // uploader url, probably all info is already there, so there is no need to fetch it | ||||
|             callback.accept(new SinglePlayQueue(item)); | ||||
|   | ||||
| @@ -14,8 +14,34 @@ public final class StreamTypeUtil { | ||||
|      * Check if the {@link StreamType} of a stream is a livestream. | ||||
|      * | ||||
|      * @param streamType the stream type of the stream | ||||
|      * @return <code>true</code> if the streamType is a | ||||
|      * {@link StreamType#LIVE_STREAM} or {@link StreamType#AUDIO_LIVE_STREAM} | ||||
|      * @return whether the stream type is {@link StreamType#AUDIO_STREAM}, | ||||
|      * {@link StreamType#AUDIO_LIVE_STREAM} or {@link StreamType#POST_LIVE_AUDIO_STREAM} | ||||
|      */ | ||||
|     public static boolean isAudio(final StreamType streamType) { | ||||
|         return streamType == StreamType.AUDIO_STREAM | ||||
|                 || streamType == StreamType.AUDIO_LIVE_STREAM | ||||
|                 || streamType == StreamType.POST_LIVE_AUDIO_STREAM; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if the {@link StreamType} of a stream is a livestream. | ||||
|      * | ||||
|      * @param streamType the stream type of the stream | ||||
|      * @return whether the stream type is {@link StreamType#VIDEO_STREAM}, | ||||
|      * {@link StreamType#LIVE_STREAM} or {@link StreamType#POST_LIVE_STREAM} | ||||
|      */ | ||||
|     public static boolean isVideo(final StreamType streamType) { | ||||
|         return streamType == StreamType.VIDEO_STREAM | ||||
|                 || streamType == StreamType.LIVE_STREAM | ||||
|                 || streamType == StreamType.POST_LIVE_STREAM; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if the {@link StreamType} of a stream is a livestream. | ||||
|      * | ||||
|      * @param streamType the stream type of the stream | ||||
|      * @return whether the stream type is {@link StreamType#LIVE_STREAM} or | ||||
|      * {@link StreamType#AUDIO_LIVE_STREAM} | ||||
|      */ | ||||
|     public static boolean isLiveStream(final StreamType streamType) { | ||||
|         return streamType == StreamType.LIVE_STREAM | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 AudricV
					AudricV