From 0124f41cd699467e1c973ea42774c89b751f576f Mon Sep 17 00:00:00 2001 From: LisoUseInAIKyrios <118716522+LisoUseInAIKyrios@users.noreply.github.com> Date: Wed, 22 Nov 2023 21:18:01 +0200 Subject: [PATCH] fix(YouTube - Custom playback speed): Fix toast error on opening playback speed menu (#522) --- .../speed/CustomPlaybackSpeedPatch.java | 62 ++++++++++++------- 1 file changed, 41 insertions(+), 21 deletions(-) diff --git a/app/src/main/java/app/revanced/integrations/patches/playback/speed/CustomPlaybackSpeedPatch.java b/app/src/main/java/app/revanced/integrations/patches/playback/speed/CustomPlaybackSpeedPatch.java index 30f79e64b1..3c2817223f 100644 --- a/app/src/main/java/app/revanced/integrations/patches/playback/speed/CustomPlaybackSpeedPatch.java +++ b/app/src/main/java/app/revanced/integrations/patches/playback/speed/CustomPlaybackSpeedPatch.java @@ -15,15 +15,23 @@ public class CustomPlaybackSpeedPatch { /** * Maximum playback speed, exclusive value. Custom speeds must be less than this value. - * Limit is required otherwise double digit speeds show up out of order in the UI selector. + * + * Going over 8x does not increase the actual playback speed any higher, + * and the UI selector starts flickering and acting weird. + * Over 10x and the speeds show up out of order in the UI selector. */ - public static final float MAXIMUM_PLAYBACK_SPEED = 10; + public static final float MAXIMUM_PLAYBACK_SPEED = 8; /** * Custom playback speeds. */ public static float[] customPlaybackSpeeds; + /** + * The last time the old playback menu was forcefully called. + */ + private static long lastTimeOldPlaybackMenuInvoked; + /** * PreferenceList entries and values, of all available playback speeds. */ @@ -101,36 +109,48 @@ public static void onFlyoutMenuCreate(RecyclerView recyclerView) { // For some reason, the custom playback speed flyout panel is activated when the user opens the share panel. (A/B tests) // Check the child count of playback speed flyout panel to prevent this issue. // Child count of playback speed flyout panel is always 8. - if (PlaybackSpeedMenuFilterPatch.isPlaybackSpeedMenuVisible - && ((ViewGroup) recyclerView.getChildAt(0)).getChildCount() == 8) { - PlaybackSpeedMenuFilterPatch.isPlaybackSpeedMenuVisible = false; - ViewGroup parentView3rd = (ViewGroup) recyclerView.getParent().getParent().getParent(); - ViewGroup parentView4th = (ViewGroup) parentView3rd.getParent(); + if (!PlaybackSpeedMenuFilterPatch.isPlaybackSpeedMenuVisible || recyclerView.getChildCount() == 0) { + return; + } + ViewGroup PlaybackSpeedParentView = (ViewGroup) recyclerView.getChildAt(0); + if (PlaybackSpeedParentView == null || PlaybackSpeedParentView.getChildCount() != 8) { + return; + } - // Dismiss View [R.id.touch_outside] is the 1st ChildView of the 4th ParentView. - // This only shows in phone layout. + PlaybackSpeedMenuFilterPatch.isPlaybackSpeedMenuVisible = false; + ViewGroup parentView3rd = (ViewGroup) recyclerView.getParent().getParent().getParent(); + ViewGroup parentView4th = (ViewGroup) parentView3rd.getParent(); - final var touchInsidedView = parentView4th.getChildAt(0); - touchInsidedView.setSoundEffectsEnabled(false); - touchInsidedView.performClick(); + // Dismiss View [R.id.touch_outside] is the 1st ChildView of the 4th ParentView. + // This only shows in phone layout. + final var touchInsidedView = parentView4th.getChildAt(0); + touchInsidedView.setSoundEffectsEnabled(false); + touchInsidedView.performClick(); - // In tablet layout there is no Dismiss View, instead we just hide all two parent views. - parentView3rd.setVisibility(View.GONE); - parentView4th.setVisibility(View.GONE); + // In tablet layout there is no Dismiss View, instead we just hide all two parent views. + parentView3rd.setVisibility(View.GONE); + parentView4th.setVisibility(View.GONE); - // This works without issues for both tablet and phone layouts, - // So no code is needed to check whether the current device is a tablet or phone. + // This works without issues for both tablet and phone layouts, + // So no code is needed to check whether the current device is a tablet or phone. - // Close the new Playback speed menu and show the old one. - showOldPlaybackSpeedMenu(); - } + // Close the new Playback speed menu and show the old one. + showOldPlaybackSpeedMenu(); } catch (Exception ex) { LogHelper.printException(() -> "onFlyoutMenuCreate failure", ex); } }); } - public static void showOldPlaybackSpeedMenu() { + private static void showOldPlaybackSpeedMenu() { + // This method is sometimes used multiple times. + // To prevent this, ignore method reuse within 1 second. + final long now = System.currentTimeMillis(); + if (now - lastTimeOldPlaybackMenuInvoked < 1000) { + LogHelper.printDebug(() -> "Ignoring call to showOldPlaybackSpeedMenu"); + return; + } + lastTimeOldPlaybackMenuInvoked = now; LogHelper.printDebug(() -> "Old video quality menu shown"); // Rest of the implementation added by patch.