summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Adrian Roos <roosa@google.com> 2016-08-05 18:53:52 +0000
committer android-build-merger <android-build-merger@google.com> 2016-08-05 18:53:52 +0000
commit3b51c256a707f7a2903f2ea44c33a2eb11473171 (patch)
tree0cbfc8d9a1628eb3ac05a3abdb2f8d5cb08e911e
parentbfe5166ac3ff83caebd5db43b6961d5dfc95ca0a (diff)
parent1f9b02b03aa0e8602609584338af83162ac374ec (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.java12
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 */);
}
});
}