Fix ANR in creating the fallback animation.
bug: 6620501
Change-Id: Ibb798cce5dd49bb5083de6f29225bae512d589f8
diff --git a/src/com/android/gallery3d/ui/GLRootView.java b/src/com/android/gallery3d/ui/GLRootView.java
index 390d587..dbdfb67 100644
--- a/src/com/android/gallery3d/ui/GLRootView.java
+++ b/src/com/android/gallery3d/ui/GLRootView.java
@@ -465,14 +465,15 @@
listener = mIdleListeners.removeFirst();
}
mRenderLock.lock();
+ boolean keepInQueue;
try {
- if (!listener.onGLIdle(mCanvas, mRenderRequested)) return;
+ keepInQueue = listener.onGLIdle(mCanvas, mRenderRequested);
} finally {
mRenderLock.unlock();
}
synchronized (mIdleListeners) {
- mIdleListeners.addLast(listener);
- if (!mRenderRequested) enable();
+ if (keepInQueue) mIdleListeners.addLast(listener);
+ if (!mRenderRequested && !mIdleListeners.isEmpty()) enable();
}
}