diff options
| author | 2016-08-05 18:53:52 +0000 | |
|---|---|---|
| committer | 2016-08-05 18:53:52 +0000 | |
| commit | 3b51c256a707f7a2903f2ea44c33a2eb11473171 (patch) | |
| tree | 0cbfc8d9a1628eb3ac05a3abdb2f8d5cb08e911e | |
| parent | bfe5166ac3ff83caebd5db43b6961d5dfc95ca0a (diff) | |
| parent | 1f9b02b03aa0e8602609584338af83162ac374ec (diff) | |
Keyguard: Improve trusted unlock while occluded am: ddcdecc952
am: 1f9b02b03a
Change-Id: I86992edb5646ed528208d2eaa32e5b6d302e9d14
| -rw-r--r-- | services/core/java/com/android/server/policy/PhoneWindowManager.java | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/services/core/java/com/android/server/policy/PhoneWindowManager.java b/services/core/java/com/android/server/policy/PhoneWindowManager.java index aacab3b4af4d..85f3ddfeab91 100644 --- a/services/core/java/com/android/server/policy/PhoneWindowManager.java +++ b/services/core/java/com/android/server/policy/PhoneWindowManager.java @@ -3643,7 +3643,10 @@ public class PhoneWindowManager implements WindowManagerPolicy { @Override public boolean canShowDismissingWindowWhileLockedLw() { - return false; + // If the keyguard is trusted, it will unlock without a challange. Therefore, windows with + // FLAG_DISMISS_KEYGUARD don't need to be force hidden, as they will unlock the phone right + // away anyways. + return mKeyguardDelegate != null && mKeyguardDelegate.isTrusted(); } private void launchAssistLongPressAction() { @@ -5342,7 +5345,10 @@ public class PhoneWindowManager implements WindowManagerPolicy { } } else if (mDismissKeyguard != DISMISS_KEYGUARD_NONE) { mKeyguardHidden = false; - if (setKeyguardOccludedLw(false)) { + final boolean trusted = mKeyguardDelegate.isTrusted(); + if (trusted) { + // No need to un-occlude keyguard - we'll dimiss it right away anyways. + } else if (setKeyguardOccludedLw(false)) { changes |= FINISH_LAYOUT_REDO_LAYOUT | FINISH_LAYOUT_REDO_CONFIG | FINISH_LAYOUT_REDO_WALLPAPER; @@ -5352,7 +5358,7 @@ public class PhoneWindowManager implements WindowManagerPolicy { mHandler.post(new Runnable() { @Override public void run() { - mKeyguardDelegate.dismiss(false /* allowWhileOccluded */); + mKeyguardDelegate.dismiss(trusted /* allowWhileOccluded */); } }); } |