Loading packages/SystemUI/src/com/android/keyguard/KeyguardStatusViewController.java +4 −24 Original line number Diff line number Diff line Loading @@ -51,8 +51,6 @@ public class KeyguardStatusViewController extends ViewController<KeyguardStatusV private final KeyguardVisibilityHelper mKeyguardVisibilityHelper; private final Rect mClipBounds = new Rect(); private int mLockScreenMode = KeyguardUpdateMonitor.LOCK_SCREEN_MODE_NORMAL; @Inject public KeyguardStatusViewController( KeyguardStatusView keyguardStatusView, Loading Loading @@ -192,28 +190,11 @@ public class KeyguardStatusViewController extends ViewController<KeyguardStatusV * Update position of the view with an optional animation */ public void updatePosition(int x, int y, float scale, boolean animate) { // We animate the status view visible/invisible using Y translation, so don't change it // while the animation is running. if (!mKeyguardVisibilityHelper.isVisibilityAnimating()) { PropertyAnimator.setProperty(mView, AnimatableProperty.Y, y, CLOCK_ANIMATION_PROPERTIES, animate); } if (mLockScreenMode == KeyguardUpdateMonitor.LOCK_SCREEN_MODE_LAYOUT_1) { // reset any prior movement PropertyAnimator.setProperty(mView, AnimatableProperty.X, 0, CLOCK_ANIMATION_PROPERTIES, animate); mKeyguardClockSwitchController.updatePosition(x, scale, CLOCK_ANIMATION_PROPERTIES, animate); } else { // reset any prior movement mKeyguardClockSwitchController.updatePosition(0, 0f, CLOCK_ANIMATION_PROPERTIES, animate); PropertyAnimator.setProperty(mView, AnimatableProperty.X, x, CLOCK_ANIMATION_PROPERTIES, animate); } } /** Loading Loading @@ -254,7 +235,6 @@ public class KeyguardStatusViewController extends ViewController<KeyguardStatusV private KeyguardUpdateMonitorCallback mInfoCallback = new KeyguardUpdateMonitorCallback() { @Override public void onLockScreenModeChanged(int mode) { mLockScreenMode = mode; mKeyguardSliceViewController.updateLockScreenMode(mode); mView.setCanShowOwnerInfo(false); mView.updateLogoutView(false); Loading packages/SystemUI/src/com/android/keyguard/KeyguardVisibilityHelper.java +15 −0 Original line number Diff line number Diff line Loading @@ -36,6 +36,7 @@ public class KeyguardVisibilityHelper { private final KeyguardStateController mKeyguardStateController; private final DozeParameters mDozeParameters; private boolean mKeyguardViewVisibilityAnimating; private boolean mLastOccludedState = false; public KeyguardVisibilityHelper(View view, KeyguardStateController keyguardStateController, DozeParameters dozeParameters) { Loading @@ -57,6 +58,7 @@ public class KeyguardVisibilityHelper { boolean goingToFullShade, int oldStatusBarState) { mView.animate().cancel(); boolean isOccluded = mKeyguardStateController.isOccluded(); mKeyguardViewVisibilityAnimating = false; if ((!keyguardFadingAway && oldStatusBarState == KEYGUARD && statusBarState != KEYGUARD) || goingToFullShade) { Loading Loading @@ -95,6 +97,17 @@ public class KeyguardVisibilityHelper { .setStartDelay(0) .withEndAction(mAnimateKeyguardStatusViewInvisibleEndRunnable) .start(); } else if (mLastOccludedState && !isOccluded) { // An activity was displayed over the lock screen, and has now gone away mView.setVisibility(View.VISIBLE); mView.setAlpha(0f); mView.animate() .setDuration(StackStateAnimator.ANIMATION_DURATION_WAKEUP) .setInterpolator(Interpolators.FAST_OUT_SLOW_IN) .alpha(1f) .withEndAction(mAnimateKeyguardStatusViewVisibleEndRunnable) .start(); } else if (mDozeParameters.shouldControlUnlockedScreenOff()) { mKeyguardViewVisibilityAnimating = true; Loading @@ -119,6 +132,8 @@ public class KeyguardVisibilityHelper { mView.setVisibility(View.GONE); mView.setAlpha(1f); } mLastOccludedState = isOccluded; } private final Runnable mAnimateKeyguardStatusViewInvisibleEndRunnable = () -> { Loading Loading
packages/SystemUI/src/com/android/keyguard/KeyguardStatusViewController.java +4 −24 Original line number Diff line number Diff line Loading @@ -51,8 +51,6 @@ public class KeyguardStatusViewController extends ViewController<KeyguardStatusV private final KeyguardVisibilityHelper mKeyguardVisibilityHelper; private final Rect mClipBounds = new Rect(); private int mLockScreenMode = KeyguardUpdateMonitor.LOCK_SCREEN_MODE_NORMAL; @Inject public KeyguardStatusViewController( KeyguardStatusView keyguardStatusView, Loading Loading @@ -192,28 +190,11 @@ public class KeyguardStatusViewController extends ViewController<KeyguardStatusV * Update position of the view with an optional animation */ public void updatePosition(int x, int y, float scale, boolean animate) { // We animate the status view visible/invisible using Y translation, so don't change it // while the animation is running. if (!mKeyguardVisibilityHelper.isVisibilityAnimating()) { PropertyAnimator.setProperty(mView, AnimatableProperty.Y, y, CLOCK_ANIMATION_PROPERTIES, animate); } if (mLockScreenMode == KeyguardUpdateMonitor.LOCK_SCREEN_MODE_LAYOUT_1) { // reset any prior movement PropertyAnimator.setProperty(mView, AnimatableProperty.X, 0, CLOCK_ANIMATION_PROPERTIES, animate); mKeyguardClockSwitchController.updatePosition(x, scale, CLOCK_ANIMATION_PROPERTIES, animate); } else { // reset any prior movement mKeyguardClockSwitchController.updatePosition(0, 0f, CLOCK_ANIMATION_PROPERTIES, animate); PropertyAnimator.setProperty(mView, AnimatableProperty.X, x, CLOCK_ANIMATION_PROPERTIES, animate); } } /** Loading Loading @@ -254,7 +235,6 @@ public class KeyguardStatusViewController extends ViewController<KeyguardStatusV private KeyguardUpdateMonitorCallback mInfoCallback = new KeyguardUpdateMonitorCallback() { @Override public void onLockScreenModeChanged(int mode) { mLockScreenMode = mode; mKeyguardSliceViewController.updateLockScreenMode(mode); mView.setCanShowOwnerInfo(false); mView.updateLogoutView(false); Loading
packages/SystemUI/src/com/android/keyguard/KeyguardVisibilityHelper.java +15 −0 Original line number Diff line number Diff line Loading @@ -36,6 +36,7 @@ public class KeyguardVisibilityHelper { private final KeyguardStateController mKeyguardStateController; private final DozeParameters mDozeParameters; private boolean mKeyguardViewVisibilityAnimating; private boolean mLastOccludedState = false; public KeyguardVisibilityHelper(View view, KeyguardStateController keyguardStateController, DozeParameters dozeParameters) { Loading @@ -57,6 +58,7 @@ public class KeyguardVisibilityHelper { boolean goingToFullShade, int oldStatusBarState) { mView.animate().cancel(); boolean isOccluded = mKeyguardStateController.isOccluded(); mKeyguardViewVisibilityAnimating = false; if ((!keyguardFadingAway && oldStatusBarState == KEYGUARD && statusBarState != KEYGUARD) || goingToFullShade) { Loading Loading @@ -95,6 +97,17 @@ public class KeyguardVisibilityHelper { .setStartDelay(0) .withEndAction(mAnimateKeyguardStatusViewInvisibleEndRunnable) .start(); } else if (mLastOccludedState && !isOccluded) { // An activity was displayed over the lock screen, and has now gone away mView.setVisibility(View.VISIBLE); mView.setAlpha(0f); mView.animate() .setDuration(StackStateAnimator.ANIMATION_DURATION_WAKEUP) .setInterpolator(Interpolators.FAST_OUT_SLOW_IN) .alpha(1f) .withEndAction(mAnimateKeyguardStatusViewVisibleEndRunnable) .start(); } else if (mDozeParameters.shouldControlUnlockedScreenOff()) { mKeyguardViewVisibilityAnimating = true; Loading @@ -119,6 +132,8 @@ public class KeyguardVisibilityHelper { mView.setVisibility(View.GONE); mView.setAlpha(1f); } mLastOccludedState = isOccluded; } private final Runnable mAnimateKeyguardStatusViewInvisibleEndRunnable = () -> { Loading