add support for the filler category (#63)

This commit is contained in:
caneleex 2022-01-24 23:01:21 +01:00
parent 8d2a84b066
commit 643dd8585d
3 changed files with 21 additions and 15 deletions

View File

@ -163,7 +163,7 @@ public class SponsorBlockPreferenceFragment extends PreferenceFragment implement
preference.setTitle(segmentInfo.getTitleWithDot()); preference.setTitle(segmentInfo.getTitleWithDot());
preference.setSummary(segmentInfo.description.toString()); preference.setSummary(segmentInfo.description.toString());
preference.setKey(segmentInfo.key); preference.setKey(segmentInfo.key);
preference.setDefaultValue(defaultValue); preference.setDefaultValue(segmentInfo.behaviour.key);
preference.setEntries(entries); preference.setEntries(entries);
preference.setEntryValues(entryValues); preference.setEntryValues(entryValues);

View File

@ -102,9 +102,7 @@ public class SponsorBlockSettings {
SegmentBehaviour behaviour = null; SegmentBehaviour behaviour = null;
String value = preferences.getString(segment.key, null); String value = preferences.getString(segment.key, null);
if (value == null) if (value != null) {
behaviour = DefaultBehaviour;
else {
for (SegmentBehaviour possibleBehaviour : possibleBehaviours) { for (SegmentBehaviour possibleBehaviour : possibleBehaviours) {
if (possibleBehaviour.key.equals(value)) { if (possibleBehaviour.key.equals(value)) {
behaviour = possibleBehaviour; behaviour = possibleBehaviour;
@ -112,10 +110,13 @@ public class SponsorBlockSettings {
} }
} }
} }
if (behaviour == null) if (behaviour != null) {
behaviour = DefaultBehaviour; segment.behaviour = behaviour;
}
else {
behaviour = segment.behaviour;
}
segment.behaviour = behaviour;
if (behaviour.showOnTimeBar && segment != SegmentInfo.UNSUBMITTED) if (behaviour.showOnTimeBar && segment != SegmentInfo.UNSUBMITTED)
enabledCategories.add(segment.key); enabledCategories.add(segment.key);
} }
@ -185,13 +186,14 @@ public class SponsorBlockSettings {
} }
public enum SegmentInfo { public enum SegmentInfo {
SPONSOR("sponsor", sf("segments_sponsor"), sf("skipped_sponsor"), sf("segments_sponsor_sum"), null, 0xFF00d400), SPONSOR("sponsor", sf("segments_sponsor"), sf("skipped_sponsor"), sf("segments_sponsor_sum"), DefaultBehaviour, 0xFF00d400),
INTRO("intro", sf("segments_intermission"), sf("skipped_intermission"), sf("segments_intermission_sum"), null, 0xFF00ffff), INTRO("intro", sf("segments_intermission"), sf("skipped_intermission"), sf("segments_intermission_sum"), DefaultBehaviour, 0xFF00ffff),
OUTRO("outro", sf("segments_endcards"), sf("skipped_endcard"), sf("segments_endcards_sum"), null, 0xFF0202ed), OUTRO("outro", sf("segments_endcards"), sf("skipped_endcard"), sf("segments_endcards_sum"), DefaultBehaviour, 0xFF0202ed),
INTERACTION("interaction", sf("segments_subscribe"), sf("skipped_subscribe"), sf("segments_subscribe_sum"), null, 0xFFcc00ff), INTERACTION("interaction", sf("segments_subscribe"), sf("skipped_subscribe"), sf("segments_subscribe_sum"), DefaultBehaviour, 0xFFcc00ff),
SELF_PROMO("selfpromo", sf("segments_selfpromo"), sf("skipped_selfpromo"), sf("segments_selfpromo_sum"), null, 0xFFffff00), SELF_PROMO("selfpromo", sf("segments_selfpromo"), sf("skipped_selfpromo"), sf("segments_selfpromo_sum"), DefaultBehaviour, 0xFFffff00),
MUSIC_OFFTOPIC("music_offtopic", sf("segments_nomusic"), sf("skipped_nomusic"), sf("segments_nomusic_sum"), null, 0xFFff9900), MUSIC_OFFTOPIC("music_offtopic", sf("segments_nomusic"), sf("skipped_nomusic"), sf("segments_nomusic_sum"), DefaultBehaviour, 0xFFff9900),
PREVIEW("preview", sf("segments_preview"), sf("skipped_preview"), sf("segments_preview_sum"), null, 0xFF008fd6), PREVIEW("preview", sf("segments_preview"), sf("skipped_preview"), sf("segments_preview_sum"), DefaultBehaviour, 0xFF008fd6),
FILLER("filler", sf("segments_filler"), sf("skipped_filler"), sf("segments_filler_sum"), SegmentBehaviour.IGNORE, 0xFF7300FF),
UNSUBMITTED("unsubmitted", StringRef.empty, sf("skipped_unsubmitted"), StringRef.empty, SegmentBehaviour.SKIP_AUTOMATICALLY, 0xFFFFFFFF); UNSUBMITTED("unsubmitted", StringRef.empty, sf("skipped_unsubmitted"), StringRef.empty, SegmentBehaviour.SKIP_AUTOMATICALLY, 0xFFFFFFFF);
private static final SegmentInfo[] mValuesWithoutUnsubmitted = new SegmentInfo[]{ private static final SegmentInfo[] mValuesWithoutUnsubmitted = new SegmentInfo[]{
@ -201,7 +203,8 @@ public class SponsorBlockSettings {
INTERACTION, INTERACTION,
SELF_PROMO, SELF_PROMO,
MUSIC_OFFTOPIC, MUSIC_OFFTOPIC,
PREVIEW PREVIEW,
FILLER
}; };
private static final Map<String, SegmentInfo> mValuesMap = new HashMap<>(values().length); private static final Map<String, SegmentInfo> mValuesMap = new HashMap<>(values().length);

View File

@ -175,6 +175,8 @@
<string name="segments_selfpromo_sum">Similar to "sponsor" except for unpaid or self promotion. This includes sections about merchandise, donations, or information about who they collaborated with</string> <string name="segments_selfpromo_sum">Similar to "sponsor" except for unpaid or self promotion. This includes sections about merchandise, donations, or information about who they collaborated with</string>
<string name="segments_nomusic">Music: Non-Music Section</string> <string name="segments_nomusic">Music: Non-Music Section</string>
<string name="segments_nomusic_sum">Only for use in music videos. This includes introductions or outros in music videos</string> <string name="segments_nomusic_sum">Only for use in music videos. This includes introductions or outros in music videos</string>
<string name="segments_filler">Filler/Tangent</string>
<string name="segments_filler_sum">Tangential scenes added only for filler or humor that are not required to understand the main content of the video. This should not include segments providing context or background details</string>
<string name="skipped_segment">Skipped a sponsor segment</string> <string name="skipped_segment">Skipped a sponsor segment</string>
<string name="skipped_sponsor">Skipped sponsor</string> <string name="skipped_sponsor">Skipped sponsor</string>
<string name="skipped_intermission">Skipped intro</string> <string name="skipped_intermission">Skipped intro</string>
@ -183,6 +185,7 @@
<string name="skipped_selfpromo">Skipped self promotion</string> <string name="skipped_selfpromo">Skipped self promotion</string>
<string name="skipped_nomusic">Skipped silence</string> <string name="skipped_nomusic">Skipped silence</string>
<string name="skipped_preview">Skipped preview</string> <string name="skipped_preview">Skipped preview</string>
<string name="skipped_filler">Skipped filler</string>
<string name="skipped_unsubmitted">Skipped unsubmitted segment</string> <string name="skipped_unsubmitted">Skipped unsubmitted segment</string>
<string name="skip_automatically">Skip automatically</string> <string name="skip_automatically">Skip automatically</string>
<string name="skip_showbutton">Show a skip button</string> <string name="skip_showbutton">Show a skip button</string>