From a54659f1817a6240739d7da6bce057cdf27ad883 Mon Sep 17 00:00:00 2001 From: Isira Seneviratne Date: Tue, 28 Mar 2023 06:46:56 +0530 Subject: [PATCH] Disable picture-in-picture controls on Android Go devices. --- .../github/libretube/compat/PictureInPictureCompat.kt | 7 +++++++ .../com/github/libretube/ui/fragments/PlayerFragment.kt | 9 ++++----- .../github/libretube/ui/preferences/PlayerSettings.kt | 6 +++--- 3 files changed, 14 insertions(+), 8 deletions(-) diff --git a/app/src/main/java/com/github/libretube/compat/PictureInPictureCompat.kt b/app/src/main/java/com/github/libretube/compat/PictureInPictureCompat.kt index 6c0b4e78d..82662f249 100644 --- a/app/src/main/java/com/github/libretube/compat/PictureInPictureCompat.kt +++ b/app/src/main/java/com/github/libretube/compat/PictureInPictureCompat.kt @@ -1,9 +1,16 @@ package com.github.libretube.compat import android.app.Activity +import android.content.Context +import android.content.pm.PackageManager import android.os.Build object PictureInPictureCompat { + fun isPictureInPictureAvailable(context: Context): Boolean { + return Build.VERSION.SDK_INT >= Build.VERSION_CODES.O && + context.packageManager.hasSystemFeature(PackageManager.FEATURE_PICTURE_IN_PICTURE) + } + fun isInPictureInPictureMode(activity: Activity): Boolean { return Build.VERSION.SDK_INT >= Build.VERSION_CODES.O && activity.isInPictureInPictureMode } diff --git a/app/src/main/java/com/github/libretube/ui/fragments/PlayerFragment.kt b/app/src/main/java/com/github/libretube/ui/fragments/PlayerFragment.kt index 067d38387..9911351c0 100644 --- a/app/src/main/java/com/github/libretube/ui/fragments/PlayerFragment.kt +++ b/app/src/main/java/com/github/libretube/ui/fragments/PlayerFragment.kt @@ -344,13 +344,12 @@ class PlayerFragment : Fragment(), OnlinePlayerOptions { binding.playerMotionLayout.progress = 1.toFloat() binding.playerMotionLayout.transitionToStart() + val activity = requireActivity() if (PlayerHelper.pipEnabled) { - PictureInPictureCompat.setPictureInPictureParams(requireActivity(), pipParams) - } - - if (Build.VERSION.SDK_INT < Build.VERSION_CODES.O) { - binding.relPlayerPip.visibility = View.GONE + PictureInPictureCompat.setPictureInPictureParams(activity, pipParams) } + binding.relPlayerPip.isVisible = PictureInPictureCompat + .isPictureInPictureAvailable(activity) } // actions that don't depend on video information diff --git a/app/src/main/java/com/github/libretube/ui/preferences/PlayerSettings.kt b/app/src/main/java/com/github/libretube/ui/preferences/PlayerSettings.kt index c6d6b05f4..cb5d20a6f 100644 --- a/app/src/main/java/com/github/libretube/ui/preferences/PlayerSettings.kt +++ b/app/src/main/java/com/github/libretube/ui/preferences/PlayerSettings.kt @@ -2,8 +2,6 @@ package com.github.libretube.ui.preferences import android.content.ActivityNotFoundException import android.content.Intent -import android.os.Build -import android.os.Build.VERSION.SDK_INT import android.os.Bundle import android.provider.Settings import android.widget.Toast @@ -11,6 +9,7 @@ import androidx.preference.ListPreference import androidx.preference.Preference import androidx.preference.SwitchPreferenceCompat import com.github.libretube.R +import com.github.libretube.compat.PictureInPictureCompat import com.github.libretube.constants.PreferenceKeys import com.github.libretube.helpers.LocaleHelper import com.github.libretube.helpers.PreferenceHelper @@ -64,7 +63,8 @@ class PlayerSettings : BasePreferenceFragment() { PreferenceKeys.PICTURE_IN_PICTURE )!! val pauseOnQuit = findPreference(PreferenceKeys.PAUSE_ON_QUIT) - pictureInPicture.isVisible = SDK_INT >= Build.VERSION_CODES.O + pictureInPicture.isVisible = PictureInPictureCompat + .isPictureInPictureAvailable(requireContext()) pauseOnQuit?.isVisible = !pictureInPicture.isVisible || !pictureInPicture.isChecked pictureInPicture.setOnPreferenceChangeListener { _, newValue ->