From cce954f334c31847cb49a8aaaa9731dcf88a9229 Mon Sep 17 00:00:00 2001 From: Kevin Date: Tue, 16 Apr 2019 10:24:12 -0700 Subject: [PATCH] Fix views not being visible on Recents Go. If we bind the loading task views but then on the tasks being loaded realize there are no items, it's possible to animate from the empty content view to the regular content view and then back. Currently, this leads to updateContentView not being called properly the second time since both views are still visible during the animation, so this CL fixes that and cancels any on-going crossfade animations. Bug: 114136250 Fixes: 130580680 Test: Remove last item from recents, go to recents again, empty view shown Change-Id: If1a4caab15f9b6d7ccd3abbc06f5866e06650db8 --- .../src/com/android/quickstep/views/IconRecentsView.java | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/go/quickstep/src/com/android/quickstep/views/IconRecentsView.java b/go/quickstep/src/com/android/quickstep/views/IconRecentsView.java index 47244068cd..f7f0c8ab84 100644 --- a/go/quickstep/src/com/android/quickstep/views/IconRecentsView.java +++ b/go/quickstep/src/com/android/quickstep/views/IconRecentsView.java @@ -99,6 +99,7 @@ public final class IconRecentsView extends FrameLayout { private RecentsToActivityHelper mActivityHelper; private RecyclerView mTaskRecyclerView; + private View mShowingContentView; private View mEmptyView; private View mContentView; private View mClearAllView; @@ -335,11 +336,13 @@ public final class IconRecentsView extends FrameLayout { */ private void updateContentViewVisibility() { int taskListSize = mTaskAdapter.getItemCount(); - if (mEmptyView.getVisibility() != VISIBLE && taskListSize == 0) { + if (mShowingContentView != mEmptyView && taskListSize == 0) { + mShowingContentView = mEmptyView; crossfadeViews(mEmptyView, mContentView); mActivityHelper.leaveRecents(); } - if (mContentView.getVisibility() != VISIBLE && taskListSize > 0) { + if (mShowingContentView != mContentView && taskListSize > 0) { + mShowingContentView = mContentView; crossfadeViews(mContentView, mEmptyView); } } @@ -351,6 +354,7 @@ public final class IconRecentsView extends FrameLayout { * @param fadeOutView view that should fade out */ private void crossfadeViews(View fadeInView, View fadeOutView) { + fadeInView.animate().cancel(); fadeInView.setVisibility(VISIBLE); fadeInView.setAlpha(0f); fadeInView.animate() @@ -358,6 +362,7 @@ public final class IconRecentsView extends FrameLayout { .setDuration(CROSSFADE_DURATION) .setListener(null); + fadeOutView.animate().cancel(); fadeOutView.animate() .alpha(0f) .setDuration(CROSSFADE_DURATION)