From fce8565e5e08ca3e2e7fd27d09dfa6b0c2dae88a Mon Sep 17 00:00:00 2001 From: Tsung-Mao Fang Date: Wed, 20 Oct 2021 18:40:44 +0800 Subject: [PATCH] Update logic to check two pane resolution Prior to this cl, we checked the app bounds for deciding app in two pane or not. However, this might be broken in some certain sceanrios. Currently, api will check the entire task bounds. If the width of task bounds is larger than two pane criteria, then we treat it as in two pane mode. Test: Highlighted behavior works correct. Fix: 203763572 Change-Id: Ib14851b1e3e097328874c7956bb653f50820f877 --- .../activityembedding/ActivityEmbeddingUtils.java | 14 +++++++++----- .../settings/homepage/TopLevelSettings.java | 4 ++-- .../HighlightableTopLevelPreferenceAdapter.java | 9 ++++++--- 3 files changed, 17 insertions(+), 10 deletions(-) diff --git a/src/com/android/settings/activityembedding/ActivityEmbeddingUtils.java b/src/com/android/settings/activityembedding/ActivityEmbeddingUtils.java index 7ecacded7be..ac3a01df8cf 100644 --- a/src/com/android/settings/activityembedding/ActivityEmbeddingUtils.java +++ b/src/com/android/settings/activityembedding/ActivityEmbeddingUtils.java @@ -16,7 +16,10 @@ package com.android.settings.activityembedding; +import android.app.Activity; +import android.app.ActivityTaskManager; import android.content.Context; +import android.graphics.Rect; import android.util.DisplayMetrics; import android.util.FeatureFlagUtils; import android.util.Log; @@ -64,10 +67,11 @@ public class ActivityEmbeddingUtils { } /** Whether the screen meets two-pane resolution. */ - public static boolean isTwoPaneResolution(Context context) { - final Context appContext = context.getApplicationContext(); - final DisplayMetrics dm = appContext.getResources().getDisplayMetrics(); - return dm.widthPixels >= getMinCurrentScreenSplitWidthPx(appContext) - && dm.heightPixels >= getMinSmallestScreenSplitWidthPx(appContext); + public static boolean isTwoPaneResolution(Activity activity) { + final Rect currentTaskBounds = + ActivityTaskManager.getInstance().getTaskBounds(activity.getTaskId()); + + return currentTaskBounds.width() >= getMinCurrentScreenSplitWidthPx(activity) + && currentTaskBounds.height() >= getMinSmallestScreenSplitWidthPx(activity); } } diff --git a/src/com/android/settings/homepage/TopLevelSettings.java b/src/com/android/settings/homepage/TopLevelSettings.java index a819b870540..38b2baa1694 100644 --- a/src/com/android/settings/homepage/TopLevelSettings.java +++ b/src/com/android/settings/homepage/TopLevelSettings.java @@ -196,8 +196,8 @@ public class TopLevelSettings extends DashboardFragment implements } Log.d(TAG, "onCreateAdapter, pref key: " + mHighlightedPreferenceKey); - mTopLevelAdapter = new HighlightableTopLevelPreferenceAdapter(preferenceScreen, - getListView(), mHighlightedPreferenceKey); + mTopLevelAdapter = new HighlightableTopLevelPreferenceAdapter( + getActivity(), preferenceScreen, getListView(), mHighlightedPreferenceKey); return mTopLevelAdapter; } diff --git a/src/com/android/settings/widget/HighlightableTopLevelPreferenceAdapter.java b/src/com/android/settings/widget/HighlightableTopLevelPreferenceAdapter.java index eeaad214a21..19a91f65d16 100644 --- a/src/com/android/settings/widget/HighlightableTopLevelPreferenceAdapter.java +++ b/src/com/android/settings/widget/HighlightableTopLevelPreferenceAdapter.java @@ -16,6 +16,7 @@ package com.android.settings.widget; +import android.app.Activity; import android.content.Context; import android.graphics.drawable.Drawable; import android.text.TextUtils; @@ -53,6 +54,7 @@ public class HighlightableTopLevelPreferenceAdapter extends PreferenceGroupAdapt final int mIconColorHighlight; private final Context mContext; + private final Activity mActivity; private final RecyclerView mRecyclerView; private final int mNormalBackgroundRes; private String mHighlightKey; @@ -61,12 +63,13 @@ public class HighlightableTopLevelPreferenceAdapter extends PreferenceGroupAdapt private boolean mHighlightNeeded; private boolean mScrolled; - public HighlightableTopLevelPreferenceAdapter(PreferenceGroup preferenceGroup, - RecyclerView recyclerView, String key) { + public HighlightableTopLevelPreferenceAdapter(Activity activity, + PreferenceGroup preferenceGroup, RecyclerView recyclerView, String key) { super(preferenceGroup); mRecyclerView = recyclerView; mHighlightKey = key; mContext = preferenceGroup.getContext(); + mActivity = activity; final TypedValue outValue = new TypedValue(); mContext.getTheme().resolveAttribute(android.R.attr.selectableItemBackground, outValue, true /* resolveRefs */); @@ -233,6 +236,6 @@ public class HighlightableTopLevelPreferenceAdapter extends PreferenceGroupAdapt } private boolean isHighlightNeeded() { - return ActivityEmbeddingUtils.isTwoPaneResolution(mContext); + return ActivityEmbeddingUtils.isTwoPaneResolution(mActivity); } }