diff options
author | Adam Cohen <adamcohen@google.com> | 2013-10-02 01:10:57 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2013-10-02 01:10:57 +0000 |
commit | 044db335abfebb4a3c3ebc82d40d157c73b7f8cb (patch) | |
tree | c0ac6e074d0455a15c9d9307dc8ec667bff62151 /src | |
parent | 20df4f87ec69e34f62bf15c7e3078db479fbfdd7 (diff) | |
parent | 7a9e58aa17d42c1251b4eea5edf117a4e8b4a6d4 (diff) | |
download | android_packages_apps_Trebuchet-044db335abfebb4a3c3ebc82d40d157c73b7f8cb.tar.gz android_packages_apps_Trebuchet-044db335abfebb4a3c3ebc82d40d157c73b7f8cb.tar.bz2 android_packages_apps_Trebuchet-044db335abfebb4a3c3ebc82d40d157c73b7f8cb.zip |
Merge "Making sure overview mode can't get stuck (issue 11022017)" into jb-ub-now-indigo-rose
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/launcher3/PagedView.java | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/src/com/android/launcher3/PagedView.java b/src/com/android/launcher3/PagedView.java index 0a15ecd62..6d7501865 100644 --- a/src/com/android/launcher3/PagedView.java +++ b/src/com/android/launcher3/PagedView.java @@ -990,13 +990,14 @@ public abstract class PagedView extends ViewGroup implements ViewGroup.OnHierarc // in accordance with any scroll effects. mForceScreenScrolled = true; mRecomputePageSpacing = true; - + updateFreescrollBounds(); invalidate(); } @Override public void onChildViewRemoved(View parent, View child) { mForceScreenScrolled = true; + updateFreescrollBounds(); invalidate(); } @@ -1558,6 +1559,17 @@ public abstract class PagedView extends ViewGroup implements ViewGroup.OnHierarc setEnableFreeScroll(false, snapPage); } + void updateFreescrollBounds() { + getOverviewModePages(mTempVisiblePagesRange); + if (isLayoutRtl()) { + mFreeScrollMinScrollX = getScrollForPage(mTempVisiblePagesRange[1]); + mFreeScrollMaxScrollX = getScrollForPage(mTempVisiblePagesRange[0]); + } else { + mFreeScrollMinScrollX = getScrollForPage(mTempVisiblePagesRange[0]); + mFreeScrollMaxScrollX = getScrollForPage(mTempVisiblePagesRange[1]); + } + } + private void setEnableFreeScroll(boolean freeScroll, int snapPage) { mFreeScroll = freeScroll; @@ -1565,18 +1577,11 @@ public abstract class PagedView extends ViewGroup implements ViewGroup.OnHierarc snapPage = getPageNearestToCenterOfScreen(); } - getOverviewModePages(mTempVisiblePagesRange); if (!mFreeScroll) { snapToPage(snapPage); } else { - if (isLayoutRtl()) { - mFreeScrollMinScrollX = getScrollForPage(mTempVisiblePagesRange[1]); - mFreeScrollMaxScrollX = getScrollForPage(mTempVisiblePagesRange[0]); - } else { - mFreeScrollMinScrollX = getScrollForPage(mTempVisiblePagesRange[0]); - mFreeScrollMaxScrollX = getScrollForPage(mTempVisiblePagesRange[1]); - } - + updateFreescrollBounds(); + getOverviewModePages(mTempVisiblePagesRange); if (getCurrentPage() < mTempVisiblePagesRange[0]) { setCurrentPage(mTempVisiblePagesRange[0]); } else if (getCurrentPage() > mTempVisiblePagesRange[1]) { |