summaryrefslogtreecommitdiffstats
path: root/core/java/android/widget/AdapterViewAnimator.java
diff options
context:
space:
mode:
authorWinson Chung <winsonc@google.com>2011-01-26 12:30:26 -0800
committerAndroid (Google) Code Review <android-gerrit@google.com>2011-01-26 12:30:26 -0800
commit2c070bae4493cd1976c5086ec4cbf6ce10482742 (patch)
tree2ced53244db2f66e13700581be425135d05ad17a /core/java/android/widget/AdapterViewAnimator.java
parente9b644fcef08b0716efd3843ca7152e75cde3447 (diff)
parent16c8d8a558f94ec14ef52bb5ac11044e2d0d902c (diff)
downloadframeworks_base-2c070bae4493cd1976c5086ec4cbf6ce10482742.zip
frameworks_base-2c070bae4493cd1976c5086ec4cbf6ce10482742.tar.gz
frameworks_base-2c070bae4493cd1976c5086ec4cbf6ce10482742.tar.bz2
Merge "Re-enabling queued unbinding of services after requests to the service. (3394210)" into honeycomb
Diffstat (limited to 'core/java/android/widget/AdapterViewAnimator.java')
-rw-r--r--core/java/android/widget/AdapterViewAnimator.java29
1 files changed, 26 insertions, 3 deletions
diff --git a/core/java/android/widget/AdapterViewAnimator.java b/core/java/android/widget/AdapterViewAnimator.java
index b505c85..d596339 100644
--- a/core/java/android/widget/AdapterViewAnimator.java
+++ b/core/java/android/widget/AdapterViewAnimator.java
@@ -54,6 +54,12 @@ public abstract class AdapterViewAnimator extends AdapterView<Adapter>
int mWhichChild = 0;
/**
+ * The index of the child to restore after the asynchronous connection from the
+ * RemoteViewsAdapter has been.
+ */
+ private int mRestoreWhichChild = -1;
+
+ /**
* Whether or not the first view(s) should be animated in
*/
boolean mAnimateFirstTime = true;
@@ -780,7 +786,15 @@ public abstract class AdapterViewAnimator extends AdapterView<Adapter>
// set mWhichChild
mWhichChild = ss.whichChild;
- setDisplayedChild(mWhichChild);
+ // When using RemoteAdapters, the async connection process can lead to
+ // onRestoreInstanceState to be called before setAdapter(), so we need to save the previous
+ // values to restore the list position after we connect, and can skip setting the displayed
+ // child until then.
+ if (mRemoteViewsAdapter != null && mAdapter == null) {
+ mRestoreWhichChild = mWhichChild;
+ } else {
+ setDisplayedChild(mWhichChild);
+ }
}
/**
@@ -957,12 +971,21 @@ public abstract class AdapterViewAnimator extends AdapterView<Adapter>
/**
* Called back when the adapter connects to the RemoteViewsService.
*/
- public void onRemoteAdapterConnected() {
+ public boolean onRemoteAdapterConnected() {
if (mRemoteViewsAdapter != mAdapter) {
setAdapter(mRemoteViewsAdapter);
+
+ // Restore the previous position (see onRestoreInstanceState)
+ if (mRestoreWhichChild > -1) {
+ setDisplayedChild(mRestoreWhichChild);
+ mRestoreWhichChild = -1;
+ }
+ return false;
} else if (mRemoteViewsAdapter != null) {
mRemoteViewsAdapter.superNotifyDataSetChanged();
+ return true;
}
+ return false;
}
/**
@@ -995,7 +1018,7 @@ public abstract class AdapterViewAnimator extends AdapterView<Adapter>
@Override
protected void onDetachedFromWindow() {
- mAdapter = null;
+ setAdapter(null);
super.onDetachedFromWindow();
}
}