diff options
author | Jorim Jaggi <jjaggi@google.com> | 2015-05-20 14:13:23 -0700 |
---|---|---|
committer | Jorim Jaggi <jjaggi@google.com> | 2015-05-26 13:34:34 -0700 |
commit | 864e64bacee1d09b60c1c8741b7195cf6ce7aa22 (patch) | |
tree | 4fdb93f457e3b14b609b4799d09da67b0ac8e794 /packages/SystemUI/src/com/android/systemui/statusbar | |
parent | 6f63a27584e555622ecf1be733983640c276d423 (diff) | |
download | frameworks_base-864e64bacee1d09b60c1c8741b7195cf6ce7aa22.zip frameworks_base-864e64bacee1d09b60c1c8741b7195cf6ce7aa22.tar.gz frameworks_base-864e64bacee1d09b60c1c8741b7195cf6ce7aa22.tar.bz2 |
Polish animations for fingerprint icon
- Make error state animation faster.
- Add animation for
-- Draw on when turning on the screen
-- Draw off when unlocking
-- Error state -> normal state
Bug: 21269675
Change-Id: If09c0a35ce194fbeeb86151d45b4cfa81c9999c5
Diffstat (limited to 'packages/SystemUI/src/com/android/systemui/statusbar')
-rw-r--r-- | packages/SystemUI/src/com/android/systemui/statusbar/phone/KeyguardBottomAreaView.java | 4 | ||||
-rw-r--r-- | packages/SystemUI/src/com/android/systemui/statusbar/phone/LockIcon.java | 54 |
2 files changed, 46 insertions, 12 deletions
diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/phone/KeyguardBottomAreaView.java b/packages/SystemUI/src/com/android/systemui/statusbar/phone/KeyguardBottomAreaView.java index efc3ea0..adee5a8 100644 --- a/packages/SystemUI/src/com/android/systemui/statusbar/phone/KeyguardBottomAreaView.java +++ b/packages/SystemUI/src/com/android/systemui/statusbar/phone/KeyguardBottomAreaView.java @@ -562,12 +562,12 @@ public class KeyguardBottomAreaView extends FrameLayout implements View.OnClickL @Override public void onScreenTurnedOn() { - mLockIcon.update(); + mLockIcon.setScreenOn(true); } @Override public void onScreenTurnedOff(int why) { - mLockIcon.update(); + mLockIcon.setScreenOn(false); } @Override diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/phone/LockIcon.java b/packages/SystemUI/src/com/android/systemui/statusbar/phone/LockIcon.java index 66f3232..2063b26 100644 --- a/packages/SystemUI/src/com/android/systemui/statusbar/phone/LockIcon.java +++ b/packages/SystemUI/src/com/android/systemui/statusbar/phone/LockIcon.java @@ -35,6 +35,11 @@ import com.android.systemui.statusbar.policy.AccessibilityController; */ public class LockIcon extends KeyguardAffordanceView { + /** + * Delay animations a bit when the screen just turned on as a heuristic to start them after + * the screen has actually turned on. + */ + private static final long ANIM_DELAY_AFTER_SCREEN_ON = 250; private static final int STATE_LOCKED = 0; private static final int STATE_LOCK_OPEN = 1; @@ -43,7 +48,9 @@ public class LockIcon extends KeyguardAffordanceView { private static final int STATE_FINGERPRINT_ERROR = 4; private int mLastState = 0; + private boolean mLastScreenOn; private boolean mTransientFpError; + private boolean mScreenOn; private final TrustDrawable mTrustDrawable; private final UnlockMethodCache mUnlockMethodCache; private AccessibilityController mAccessibilityController; @@ -76,6 +83,11 @@ public class LockIcon extends KeyguardAffordanceView { update(); } + public void setScreenOn(boolean screenOn) { + mScreenOn = screenOn; + update(); + } + public void update() { boolean visible = isShown() && KeyguardUpdateMonitor.getInstance(mContext).isScreenOn(); if (visible) { @@ -89,16 +101,18 @@ public class LockIcon extends KeyguardAffordanceView { // TODO: Real icon for facelock. int state = getState(); boolean anyFingerprintIcon = state == STATE_FINGERPRINT || state == STATE_FINGERPRINT_ERROR; - if (state != mLastState) { - int iconRes = getAnimationResForTransition(mLastState, state); + if (state != mLastState || mScreenOn != mLastScreenOn) { + int iconRes = getAnimationResForTransition(mLastState, state, mLastScreenOn, mScreenOn); + if (iconRes == R.drawable.lockscreen_fingerprint_draw_off_animation) { + anyFingerprintIcon = true; + } if (iconRes == -1) { iconRes = getIconForState(state); } Drawable icon = mContext.getDrawable(iconRes); - AnimatedVectorDrawable animation = null; - if (icon instanceof AnimatedVectorDrawable) { - animation = (AnimatedVectorDrawable) icon; - } + final AnimatedVectorDrawable animation = icon instanceof AnimatedVectorDrawable + ? (AnimatedVectorDrawable) icon + : null; int iconHeight = getResources().getDimensionPixelSize( R.dimen.keyguard_affordance_icon_height); int iconWidth = getResources().getDimensionPixelSize( @@ -115,14 +129,27 @@ public class LockIcon extends KeyguardAffordanceView { anyFingerprintIcon ? 1f : KeyguardAffordanceHelper.SWIPE_RESTING_ALPHA_AMOUNT); setImageDrawable(icon); if (animation != null) { - animation.start(); + + // If we play the draw on animation, delay it by one frame when the screen is + // actually turned on. + if (iconRes == R.drawable.lockscreen_fingerprint_draw_on_animation) { + postOnAnimationDelayed(new Runnable() { + @Override + public void run() { + animation.start(); + } + }, ANIM_DELAY_AFTER_SCREEN_ON); + } else { + animation.start(); + } } + mLastState = state; + mLastScreenOn = mScreenOn; } // Hide trust circle when fingerprint is running. boolean trustManaged = mUnlockMethodCache.isTrustManaged() && !anyFingerprintIcon; mTrustDrawable.setTrustManaged(trustManaged); - mLastState = state; updateClickability(); } @@ -161,9 +188,16 @@ public class LockIcon extends KeyguardAffordanceView { } } - private int getAnimationResForTransition(int oldState, int newState) { + private int getAnimationResForTransition(int oldState, int newState, boolean oldScreenOn, + boolean screenOn) { if (oldState == STATE_FINGERPRINT && newState == STATE_FINGERPRINT_ERROR) { - return R.drawable.lockscreen_fingerprint_error_state_animation; + return R.drawable.lockscreen_fingerprint_fp_to_error_state_animation; + } else if (oldState == STATE_FINGERPRINT_ERROR && newState == STATE_FINGERPRINT) { + return R.drawable.lockscreen_fingerprint_error_state_to_fp_animation; + } else if (oldState == STATE_FINGERPRINT && newState == STATE_LOCK_OPEN) { + return R.drawable.lockscreen_fingerprint_draw_off_animation; + } else if (newState == STATE_FINGERPRINT && !oldScreenOn && screenOn) { + return R.drawable.lockscreen_fingerprint_draw_on_animation; } else { return -1; } |