diff options
author | Selim Cinek <cinek@google.com> | 2014-05-01 23:01:58 +0200 |
---|---|---|
committer | Selim Cinek <cinek@google.com> | 2014-05-01 23:09:41 +0200 |
commit | 319bdc45421b6a2239f259a0a26a44406a4b4a9b (patch) | |
tree | de66e072ba904034a62a691d60c1b78397e94836 /packages/SystemUI/src | |
parent | f4c1996d015a3c74e00c6ef72968f90f615a4bf7 (diff) | |
download | frameworks_base-319bdc45421b6a2239f259a0a26a44406a4b4a9b.zip frameworks_base-319bdc45421b6a2239f259a0a26a44406a4b4a9b.tar.gz frameworks_base-319bdc45421b6a2239f259a0a26a44406a4b4a9b.tar.bz2 |
Opimized the number of calls to updateChildren.
Improved the performance by batching multiple calls to updateChildren
to a single call on preDraw.
Change-Id: I386edeb15ac35201d39afcac8beaa48b09245448
Diffstat (limited to 'packages/SystemUI/src')
-rw-r--r-- | packages/SystemUI/src/com/android/systemui/statusbar/stack/NotificationStackScrollLayout.java | 39 |
1 files changed, 21 insertions, 18 deletions
diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/stack/NotificationStackScrollLayout.java b/packages/SystemUI/src/com/android/systemui/statusbar/stack/NotificationStackScrollLayout.java index 18677b2..4c0962e 100644 --- a/packages/SystemUI/src/com/android/systemui/statusbar/stack/NotificationStackScrollLayout.java +++ b/packages/SystemUI/src/com/android/systemui/statusbar/stack/NotificationStackScrollLayout.java @@ -106,13 +106,15 @@ public class NotificationStackScrollLayout extends ViewGroup private ExpandableView.OnHeightChangedListener mOnHeightChangedListener; private boolean mChildHierarchyDirty; private boolean mIsExpanded = true; - private ViewTreeObserver.OnPreDrawListener mAfterLayoutPreDrawListener + private boolean mChildrenNeedUpdate; + private ViewTreeObserver.OnPreDrawListener mPreDrawListener = new ViewTreeObserver.OnPreDrawListener() { @Override public boolean onPreDraw() { - updateScrollPositionIfNecessary(); - updateChildren(); - getViewTreeObserver().removeOnPreDrawListener(this); + if (mChildrenNeedUpdate) { + updateChildren(); + mChildrenNeedUpdate = false; + } return true; } }; @@ -179,6 +181,7 @@ public class NotificationStackScrollLayout extends ViewGroup mPaddingBetweenElements = context.getResources() .getDimensionPixelSize(R.dimen.notification_padding); mStackScrollAlgorithm = new StackScrollAlgorithm(context); + getViewTreeObserver().addOnPreDrawListener(mPreDrawListener); } @Override @@ -206,7 +209,8 @@ public class NotificationStackScrollLayout extends ViewGroup } setMaxLayoutHeight(getHeight() - mEmptyMarginBottom); updateContentHeight(); - getViewTreeObserver().addOnPreDrawListener(mAfterLayoutPreDrawListener); + updateScrollPositionIfNecessary(); + requestChildrenUpdate(); } public void setChildLocationsChangedListener(OnChildLocationsChangedListener listener) { @@ -270,6 +274,11 @@ public class NotificationStackScrollLayout extends ViewGroup } } + private void requestChildrenUpdate() { + mChildrenNeedUpdate = true; + invalidate(); + } + private boolean isCurrentlyAnimating() { return mStateAnimator.isRunning(); } @@ -290,7 +299,7 @@ public class NotificationStackScrollLayout extends ViewGroup mTopPadding = topPadding; updateAlgorithmHeightAndPadding(); updateContentHeight(); - updateChildren(); + requestChildrenUpdate(); } } @@ -325,7 +334,7 @@ public class NotificationStackScrollLayout extends ViewGroup if (stackHeight != mCurrentStackHeight) { mCurrentStackHeight = stackHeight; updateAlgorithmHeightAndPadding(); - updateChildren(); + requestChildrenUpdate(); } } @@ -376,7 +385,7 @@ public class NotificationStackScrollLayout extends ViewGroup public View getChildAtRawPosition(float touchX, float touchY) { int[] location = new int[2]; getLocationOnScreen(location); - return getChildAtPosition(touchX - location[0],touchY - location[1]); + return getChildAtPosition(touchX - location[0], touchY - location[1]); } public View getChildAtPosition(float touchX, float touchY) { @@ -659,19 +668,13 @@ public class NotificationStackScrollLayout extends ViewGroup } } - public void customScrollBy(int y) { - mOwnScrollY += y; - updateChildren(); - } - - public void customScrollTo(int y) { + private void customScrollTo(int y) { mOwnScrollY = y; updateChildren(); } @Override - protected void onOverScrolled(int scrollX, int scrollY, - boolean clampedX, boolean clampedY) { + protected void onOverScrolled(int scrollX, int scrollY, boolean clampedX, boolean clampedY) { // Treat animating scrolls differently; see #computeScroll() for why. if (!mScroller.isFinished()) { final int oldX = mScrollX; @@ -1115,7 +1118,7 @@ public class NotificationStackScrollLayout extends ViewGroup if (mOnHeightChangedListener != null) { mOnHeightChangedListener.onHeightChanged(view); } - updateChildren(); + requestChildrenUpdate(); } } @@ -1125,7 +1128,7 @@ public class NotificationStackScrollLayout extends ViewGroup } public void onChildAnimationFinished() { - updateChildren(); + requestChildrenUpdate(); mAnimationEvents.clear(); } |