From 00262b4a493b9cefc7477b3edcd43d6311caf9a1 Mon Sep 17 00:00:00 2001 From: bopol Date: Sat, 25 Apr 2020 11:35:15 +0200 Subject: [PATCH] =?UTF-8?q?Better=20detection=20of=20TV=C2=A0devices?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Some devices were not detected as TV even though they are --- .../java/org/schabi/newpipe/MainActivity.java | 6 ++-- .../org/schabi/newpipe/RouterActivity.java | 2 +- .../newpipe/download/DownloadActivity.java | 2 +- .../fragments/detail/VideoDetailFragment.java | 2 +- .../fragments/list/search/SearchFragment.java | 2 +- .../holder/CommentsMiniInfoItemHolder.java | 2 +- .../newpipe/player/MainVideoPlayer.java | 9 ++--- .../newpipe/settings/SettingsActivity.java | 2 +- .../schabi/newpipe/util/AndroidTvUtils.java | 35 +++++++++++++++---- 9 files changed, 43 insertions(+), 19 deletions(-) diff --git a/app/src/main/java/org/schabi/newpipe/MainActivity.java b/app/src/main/java/org/schabi/newpipe/MainActivity.java index 164a2839aa2..6f1862f319b 100644 --- a/app/src/main/java/org/schabi/newpipe/MainActivity.java +++ b/app/src/main/java/org/schabi/newpipe/MainActivity.java @@ -64,8 +64,8 @@ import org.schabi.newpipe.fragments.detail.VideoDetailFragment; import org.schabi.newpipe.fragments.list.search.SearchFragment; import org.schabi.newpipe.report.ErrorActivity; -import org.schabi.newpipe.util.Constants; import org.schabi.newpipe.util.AndroidTvUtils; +import org.schabi.newpipe.util.Constants; import org.schabi.newpipe.util.KioskTranslator; import org.schabi.newpipe.util.Localization; import org.schabi.newpipe.util.NavigationHelper; @@ -145,7 +145,7 @@ && getSupportFragmentManager().getBackStackEntryCount() == 0) { ErrorActivity.reportUiError(this, e); } - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(this)) { FocusOverlayView.setupFocusObserver(this); } } @@ -532,7 +532,7 @@ public void onBackPressed() { Log.d(TAG, "onBackPressed() called"); } - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(this)) { View drawerPanel = findViewById(R.id.navigation); if (drawer.isDrawerOpen(drawerPanel)) { drawer.closeDrawers(); diff --git a/app/src/main/java/org/schabi/newpipe/RouterActivity.java b/app/src/main/java/org/schabi/newpipe/RouterActivity.java index 264644c7468..c927a910f62 100644 --- a/app/src/main/java/org/schabi/newpipe/RouterActivity.java +++ b/app/src/main/java/org/schabi/newpipe/RouterActivity.java @@ -344,7 +344,7 @@ private void showDialog(final List choices) { alertDialog.show(); - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(this)) { FocusOverlayView.setupFocusObserver(alertDialog); } } diff --git a/app/src/main/java/org/schabi/newpipe/download/DownloadActivity.java b/app/src/main/java/org/schabi/newpipe/download/DownloadActivity.java index c5a0c3a2286..e46ded40d42 100644 --- a/app/src/main/java/org/schabi/newpipe/download/DownloadActivity.java +++ b/app/src/main/java/org/schabi/newpipe/download/DownloadActivity.java @@ -57,7 +57,7 @@ public void onGlobalLayout() { } }); - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(this)) { FocusOverlayView.setupFocusObserver(this); } } diff --git a/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java b/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java index eba77847bf2..35352c013ac 100644 --- a/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java +++ b/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java @@ -539,7 +539,7 @@ protected void initViews(final View rootView, final Bundle savedInstanceState) { thumbnailBackgroundButton.requestFocus(); - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(getContext())) { // remove ripple effects from detail controls final int transparent = getResources().getColor(R.color.transparent_background_color); detailControlsAddToPlaylist.setBackgroundColor(transparent); diff --git a/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java b/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java index 71a530b3935..ffce053b0b0 100644 --- a/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java +++ b/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java @@ -511,7 +511,7 @@ private void initSearchListeners() { if (isSuggestionsEnabled && errorPanelRoot.getVisibility() != View.VISIBLE) { showSuggestionsPanel(); } - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(getContext())) { showKeyboardSearch(); } }); diff --git a/app/src/main/java/org/schabi/newpipe/info_list/holder/CommentsMiniInfoItemHolder.java b/app/src/main/java/org/schabi/newpipe/info_list/holder/CommentsMiniInfoItemHolder.java index 8522499ab2e..7214a05d6a9 100644 --- a/app/src/main/java/org/schabi/newpipe/info_list/holder/CommentsMiniInfoItemHolder.java +++ b/app/src/main/java/org/schabi/newpipe/info_list/holder/CommentsMiniInfoItemHolder.java @@ -129,7 +129,7 @@ public void updateFromItem(final InfoItem infoItem, itemView.setOnLongClickListener(view -> { - if (!AndroidTvUtils.isTv()) { + if (!AndroidTvUtils.isTv(itemBuilder.getContext())) { ClipboardManager clipboardManager = (ClipboardManager) itemBuilder.getContext() .getSystemService(Context.CLIPBOARD_SERVICE); clipboardManager.setPrimaryClip(ClipData.newPlainText(null, commentText)); diff --git a/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java b/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java index d2b1dbd5980..5708194330d 100644 --- a/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java +++ b/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java @@ -179,7 +179,7 @@ public void onChange(final boolean selfChange) { final String orientKey = getString(R.string.last_orientation_landscape_key); final boolean lastOrientationWasLandscape = defaultPreferences - .getBoolean(orientKey, AndroidTvUtils.isTv()); + .getBoolean(orientKey, AndroidTvUtils.isTv(getApplicationContext())); setLandscape(lastOrientationWasLandscape); } else { setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_UNSPECIFIED); @@ -191,7 +191,7 @@ public void onChange(final boolean selfChange) { Settings.System.getUriFor(Settings.System.ACCELEROMETER_ROTATION), false, rotationObserver); - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(this)) { FocusOverlayView.setupFocusObserver(this); } } @@ -223,7 +223,8 @@ public boolean onKeyDown(final int keyCode, final KeyEvent event) { default: break; case KeyEvent.KEYCODE_BACK: - if (AndroidTvUtils.isTv() && playerImpl.isControlsVisible()) { + if (AndroidTvUtils.isTv(getApplicationContext()) + && playerImpl.isControlsVisible()) { playerImpl.hideControls(0, 0); hideSystemUi(); return true; @@ -271,7 +272,7 @@ protected void onResume() { final String orientKey = getString(R.string.last_orientation_landscape_key); boolean lastOrientationWasLandscape = defaultPreferences - .getBoolean(orientKey, AndroidTvUtils.isTv()); + .getBoolean(orientKey, AndroidTvUtils.isTv(getApplicationContext())); setLandscape(lastOrientationWasLandscape); } diff --git a/app/src/main/java/org/schabi/newpipe/settings/SettingsActivity.java b/app/src/main/java/org/schabi/newpipe/settings/SettingsActivity.java index 46691aa4a7b..18cbece6fb4 100644 --- a/app/src/main/java/org/schabi/newpipe/settings/SettingsActivity.java +++ b/app/src/main/java/org/schabi/newpipe/settings/SettingsActivity.java @@ -62,7 +62,7 @@ protected void onCreate(final Bundle savedInstanceBundle) { .commit(); } - if (AndroidTvUtils.isTv()) { + if (AndroidTvUtils.isTv(this)) { FocusOverlayView.setupFocusObserver(this); } } diff --git a/app/src/main/java/org/schabi/newpipe/util/AndroidTvUtils.java b/app/src/main/java/org/schabi/newpipe/util/AndroidTvUtils.java index f47eb71077b..29c17a9c3a9 100644 --- a/app/src/main/java/org/schabi/newpipe/util/AndroidTvUtils.java +++ b/app/src/main/java/org/schabi/newpipe/util/AndroidTvUtils.java @@ -1,22 +1,45 @@ package org.schabi.newpipe.util; import android.annotation.SuppressLint; +import android.app.UiModeManager; +import android.content.Context; import android.content.pm.PackageManager; - +import android.content.res.Configuration; +import android.os.BatteryManager; import android.view.KeyEvent; + import org.schabi.newpipe.App; +import static android.content.Context.BATTERY_SERVICE; +import static android.content.Context.UI_MODE_SERVICE; + public final class AndroidTvUtils { private static final String AMAZON_FEATURE_FIRE_TV = "amazon.hardware.fire_tv"; - private AndroidTvUtils() { } + private AndroidTvUtils() { + } @SuppressLint("InlinedApi") - public static boolean isTv() { - PackageManager pm = App.getApp().getPackageManager(); + public static boolean isTv(final Context context) { + PackageManager pm = App.getApp().getPackageManager(); + + + // from doc: https://developer.android.com/training/tv/start/hardware.html#runtime-check + boolean isAndroidTv = ((UiModeManager) context.getSystemService(UI_MODE_SERVICE)) + .getCurrentModeType() == Configuration.UI_MODE_TYPE_TELEVISION; + + boolean isBatteryAbsent = ((BatteryManager) context.getSystemService(BATTERY_SERVICE)) + .getIntProperty(BatteryManager.BATTERY_PROPERTY_CAPACITY) == 0; + + return isAndroidTv + || pm.hasSystemFeature(AMAZON_FEATURE_FIRE_TV) + || pm.hasSystemFeature(PackageManager.FEATURE_LEANBACK) + || pm.hasSystemFeature(PackageManager.FEATURE_TELEVISION) - return pm.hasSystemFeature(AMAZON_FEATURE_FIRE_TV) - || pm.hasSystemFeature(PackageManager.FEATURE_LEANBACK); + //from https://stackoverflow.com/a/58932366 + || (isBatteryAbsent && !pm.hasSystemFeature(PackageManager.FEATURE_TOUCHSCREEN) + && pm.hasSystemFeature(PackageManager.FEATURE_USB_HOST) + && pm.hasSystemFeature(PackageManager.FEATURE_ETHERNET)); } public static boolean isConfirmKey(final int keyCode) {