From dfb57cdcfc6a1fd48395c13af98ecc2722fd5254 Mon Sep 17 00:00:00 2001 From: Jim Miller Date: Thu, 30 May 2013 16:43:53 -0700 Subject: Fix keyguard issue where an incoming SMS would switch widget This fixes a bug where an incoming notification from AudioManager would trigger showAppropriateWidgetPage() to be called even though nothing has changed. Fixes bug 9202611 Change-Id: If8bbd30b6b324233b5ad6552183c10cc5a335061 --- .../policy/impl/keyguard/KeyguardHostView.java | 23 ++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) (limited to 'policy') diff --git a/policy/src/com/android/internal/policy/impl/keyguard/KeyguardHostView.java b/policy/src/com/android/internal/policy/impl/keyguard/KeyguardHostView.java index c470870..c3077c7 100644 --- a/policy/src/com/android/internal/policy/impl/keyguard/KeyguardHostView.java +++ b/policy/src/com/android/internal/policy/impl/keyguard/KeyguardHostView.java @@ -118,7 +118,6 @@ public class KeyguardHostView extends KeyguardViewBase { private KeyguardMultiUserSelectorView mKeyguardMultiUserSelectorView; - protected int mPlaybackState; protected int mClientGeneration; /*package*/ interface UserSwitcherCallback { @@ -205,10 +204,9 @@ public class KeyguardHostView extends KeyguardViewBase { .getCachedDisplayClientState(); mTransportState = (dcs.clearing ? TRANSPORT_GONE : (isMusicPlaying(dcs.playbackState) ? TRANSPORT_VISIBLE : TRANSPORT_INVISIBLE)); - mPlaybackState = dcs.playbackState; if (DEBUG) Log.v(TAG, "Initial transport state: " - + mTransportState + ", pbstate=" + mPlaybackState); + + mTransportState + ", pbstate=" + dcs.playbackState); } private void cleanupAppWidgetIds() { @@ -274,18 +272,27 @@ public class KeyguardHostView extends KeyguardViewBase { Log.v(TAG, (clearing ? "hide" : "show") + " transport, gen:" + clientGeneration); } mClientGeneration = clientGeneration; - mTransportState = (clearing ? TRANSPORT_GONE : TRANSPORT_INVISIBLE); - KeyguardHostView.this.post(mSwitchPageRunnable); + final int newState = (clearing ? TRANSPORT_GONE + : (mTransportState == TRANSPORT_VISIBLE ? + TRANSPORT_VISIBLE : TRANSPORT_INVISIBLE)); + if (newState != mTransportState) { + mTransportState = newState; + if (DEBUGXPORT) Log.v(TAG, "update widget: transport state changed"); + KeyguardHostView.this.post(mSwitchPageRunnable); + } } @Override public void onMusicPlaybackStateChanged(int playbackState, long eventTime) { - mPlaybackState = playbackState; if (DEBUGXPORT) Log.v(TAG, "music state changed: " + playbackState); if (mTransportState != TRANSPORT_GONE) { - mTransportState = (isMusicPlaying(mPlaybackState) ? + final int newState = (isMusicPlaying(playbackState) ? TRANSPORT_VISIBLE : TRANSPORT_INVISIBLE); + if (newState != mTransportState) { + mTransportState = newState; + if (DEBUGXPORT) Log.v(TAG, "update widget: play state changed"); + KeyguardHostView.this.post(mSwitchPageRunnable); + } } - KeyguardHostView.this.post(mSwitchPageRunnable); } }; -- cgit v1.1