From ad9fbf46997697d531f2c4eefcf478cb29dba72f Mon Sep 17 00:00:00 2001 From: Atemu Date: Fri, 13 Aug 2021 14:55:46 +0200 Subject: [PATCH] Player: Move segment marking and color parsing to SponsorBlockUtils --- .../org/schabi/newpipe/player/Player.java | 104 +--------------- .../newpipe/util/SponsorBlockUtils.java | 115 ++++++++++++++++++ 2 files changed, 117 insertions(+), 102 deletions(-) diff --git a/app/src/main/java/org/schabi/newpipe/player/Player.java b/app/src/main/java/org/schabi/newpipe/player/Player.java index f5ae57382..11f546d8f 100644 --- a/app/src/main/java/org/schabi/newpipe/player/Player.java +++ b/app/src/main/java/org/schabi/newpipe/player/Player.java @@ -132,7 +132,6 @@ import org.schabi.newpipe.util.external_communication.ShareUtils; import org.schabi.newpipe.util.SponsorBlockMode; import org.schabi.newpipe.util.VideoSegment; import org.schabi.newpipe.views.ExpandableSurfaceView; -import org.schabi.newpipe.views.SeekBarMarker; import java.io.IOException; import java.util.ArrayList; @@ -192,6 +191,7 @@ import static org.schabi.newpipe.util.ListHelper.getPopupResolutionIndex; import static org.schabi.newpipe.util.ListHelper.getResolutionIndex; import static org.schabi.newpipe.util.Localization.assureCorrectAppLanguage; import static org.schabi.newpipe.util.Localization.containsCaseInsensitive; +import static org.schabi.newpipe.util.SponsorBlockUtils.markSegments; public final class Player implements EventListener, @@ -2132,7 +2132,7 @@ public final class Player implements audioReactor.requestAudioFocus(); } - markSegments(); + markSegments(currentItem, binding.playbackSeekBar, context, prefs); } private void onBlocked() { @@ -4438,106 +4438,6 @@ public final class Player implements return null; } - private void markSegments() { - binding.playbackSeekBar.clearMarkers(); - - if (currentItem == null) { - Log.w(TAG, "markSegments() - currentItem was null"); - return; - } - - final VideoSegment[] segments = currentItem.getVideoSegments(); - - if (segments == null || segments.length == 0) { - return; - } - - for (final VideoSegment segment : segments) { - final Integer color = parseSegmentCategory(segment.category); - - // if null, then this category should not be marked - if (color == null) { - continue; - } - - final SeekBarMarker seekBarMarker = - new SeekBarMarker(segment.startTime, segment.endTime, - (int) simpleExoPlayer.getDuration(), color); - binding.playbackSeekBar.seekBarMarkers.add(seekBarMarker); - } - - binding.playbackSeekBar.drawMarkers(); - } - - private Integer parseSegmentCategory(final String category) { - String key; - final String colorStr; - switch (category) { - case "sponsor": - key = context.getString(R.string.sponsor_block_category_sponsor_key); - if (prefs.getBoolean(key, false)) { - key = context.getString(R.string.sponsor_block_category_sponsor_color_key); - colorStr = prefs.getString(key, null); - return colorStr == null - ? context.getResources().getColor(R.color.sponsor_segment) - : Color.parseColor(colorStr); - } - break; - case "intro": - key = context.getString(R.string.sponsor_block_category_intro_key); - if (prefs.getBoolean(key, false)) { - key = context.getString(R.string.sponsor_block_category_intro_color_key); - colorStr = prefs.getString(key, null); - return colorStr == null - ? context.getResources().getColor(R.color.intro_segment) - : Color.parseColor(colorStr); - } - break; - case "outro": - key = context.getString(R.string.sponsor_block_category_outro_key); - if (prefs.getBoolean(key, false)) { - key = context.getString(R.string.sponsor_block_category_outro_color_key); - colorStr = prefs.getString(key, null); - return colorStr == null - ? context.getResources().getColor(R.color.outro_segment) - : Color.parseColor(colorStr); - } - break; - case "interaction": - key = context.getString(R.string.sponsor_block_category_interaction_key); - if (prefs.getBoolean(key, false)) { - key = context.getString(R.string.sponsor_block_category_interaction_color_key); - colorStr = prefs.getString(key, null); - return colorStr == null - ? context.getResources().getColor(R.color.interaction_segment) - : Color.parseColor(colorStr); - } - break; - case "selfpromo": - key = context.getString(R.string.sponsor_block_category_self_promo_key); - if (prefs.getBoolean(key, false)) { - key = context.getString(R.string.sponsor_block_category_self_promo_color_key); - colorStr = prefs.getString(key, null); - return colorStr == null - ? context.getResources().getColor(R.color.self_promo_segment) - : Color.parseColor(colorStr); - } - break; - case "music_offtopic": - key = context.getString(R.string.sponsor_block_category_non_music_key); - if (prefs.getBoolean(key, false)) { - key = context.getString(R.string.sponsor_block_category_non_music_color_key); - colorStr = prefs.getString(key, null); - return colorStr == null - ? context.getResources().getColor(R.color.non_music_segment) - : Color.parseColor(colorStr); - } - break; - } - - return null; - } - protected void setBlockSponsorsButton(final ImageButton button) { if (button == null) { return; diff --git a/app/src/main/java/org/schabi/newpipe/util/SponsorBlockUtils.java b/app/src/main/java/org/schabi/newpipe/util/SponsorBlockUtils.java index c87da1b1c..cf9e715d0 100644 --- a/app/src/main/java/org/schabi/newpipe/util/SponsorBlockUtils.java +++ b/app/src/main/java/org/schabi/newpipe/util/SponsorBlockUtils.java @@ -3,6 +3,7 @@ package org.schabi.newpipe.util; import android.app.Application; import android.content.Context; import android.content.SharedPreferences; +import android.graphics.Color; import android.net.ConnectivityManager; import android.text.TextUtils; import android.util.Log; @@ -18,6 +19,9 @@ import org.schabi.newpipe.DownloaderImpl; import org.schabi.newpipe.MainActivity; import org.schabi.newpipe.R; import org.schabi.newpipe.extractor.stream.StreamInfo; +import org.schabi.newpipe.player.playqueue.PlayQueueItem; +import org.schabi.newpipe.views.MarkableSeekBar; +import org.schabi.newpipe.views.SeekBarMarker; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; @@ -195,4 +199,115 @@ public final class SponsorBlockUtils { return null; } } + + static Integer parseSegmentCategory( + final String category, + final Context context, + final SharedPreferences prefs + ) { + String key; + final String colorStr; + switch (category) { + case "sponsor": + key = context.getString(R.string.sponsor_block_category_sponsor_key); + if (prefs.getBoolean(key, false)) { + key = context.getString(R.string.sponsor_block_category_sponsor_color_key); + colorStr = prefs.getString(key, null); + return colorStr == null + ? context.getResources().getColor(R.color.sponsor_segment) + : Color.parseColor(colorStr); + } + break; + case "intro": + key = context.getString(R.string.sponsor_block_category_intro_key); + if (prefs.getBoolean(key, false)) { + key = context.getString(R.string.sponsor_block_category_intro_color_key); + colorStr = prefs.getString(key, null); + return colorStr == null + ? context.getResources().getColor(R.color.intro_segment) + : Color.parseColor(colorStr); + } + break; + case "outro": + key = context.getString(R.string.sponsor_block_category_outro_key); + if (prefs.getBoolean(key, false)) { + key = context.getString(R.string.sponsor_block_category_outro_color_key); + colorStr = prefs.getString(key, null); + return colorStr == null + ? context.getResources().getColor(R.color.outro_segment) + : Color.parseColor(colorStr); + } + break; + case "interaction": + key = context.getString(R.string.sponsor_block_category_interaction_key); + if (prefs.getBoolean(key, false)) { + key = context.getString(R.string.sponsor_block_category_interaction_color_key); + colorStr = prefs.getString(key, null); + return colorStr == null + ? context.getResources().getColor(R.color.interaction_segment) + : Color.parseColor(colorStr); + } + break; + case "selfpromo": + key = context.getString(R.string.sponsor_block_category_self_promo_key); + if (prefs.getBoolean(key, false)) { + key = context.getString(R.string.sponsor_block_category_self_promo_color_key); + colorStr = prefs.getString(key, null); + return colorStr == null + ? context.getResources().getColor(R.color.self_promo_segment) + : Color.parseColor(colorStr); + } + break; + case "music_offtopic": + key = context.getString(R.string.sponsor_block_category_non_music_key); + if (prefs.getBoolean(key, false)) { + key = context.getString(R.string.sponsor_block_category_non_music_color_key); + colorStr = prefs.getString(key, null); + return colorStr == null + ? context.getResources().getColor(R.color.non_music_segment) + : Color.parseColor(colorStr); + } + break; + } + + return null; + } + + public static void markSegments( + final PlayQueueItem currentItem, + final MarkableSeekBar seekBar, + final Context context, + final SharedPreferences prefs + ) { + seekBar.clearMarkers(); + + if (currentItem == null) { + return; + } + + final VideoSegment[] segments = currentItem.getVideoSegments(); + + if (segments == null || segments.length == 0) { + return; + } + + for (final VideoSegment segment : segments) { + final Integer color = parseSegmentCategory(segment.category, context, prefs); + + // if null, then this category should not be marked + if (color == null) { + continue; + } + + // Duration is in seconds, we need millis + final int length = (int) currentItem.getDuration() * 1000; + + final SeekBarMarker seekBarMarker = + new SeekBarMarker(segment.startTime, segment.endTime, + length, color); + seekBar.seekBarMarkers.add(seekBarMarker); + } + + seekBar.drawMarkers(); + } }