diff options
author | Alan Viverette <alanv@google.com> | 2015-07-30 11:44:12 -0400 |
---|---|---|
committer | Alan Viverette <alanv@google.com> | 2015-07-30 11:44:12 -0400 |
commit | da2f3044092318d44173bdb9918f31c592b86a73 (patch) | |
tree | 828c8ae121e0ac3d1e13b6c400aa22c26372c7a2 | |
parent | 30c5da9cc20cc4b9ce820963c6f58d7826f46eaa (diff) | |
download | frameworks_base-da2f3044092318d44173bdb9918f31c592b86a73.zip frameworks_base-da2f3044092318d44173bdb9918f31c592b86a73.tar.gz frameworks_base-da2f3044092318d44173bdb9918f31c592b86a73.tar.bz2 |
Include non-zero dimension views in excess space calculation
Bug: 22840778
Change-Id: Iba44c59bbaa48f63b26f342e0510b4c421e8748b
-rw-r--r-- | core/java/android/widget/LinearLayout.java | 48 |
1 files changed, 30 insertions, 18 deletions
diff --git a/core/java/android/widget/LinearLayout.java b/core/java/android/widget/LinearLayout.java index 4b40501..47e894a 100644 --- a/core/java/android/widget/LinearLayout.java +++ b/core/java/android/widget/LinearLayout.java @@ -722,8 +722,10 @@ public class LinearLayout extends ViewGroup { LinearLayout.LayoutParams lp = (LinearLayout.LayoutParams) child.getLayoutParams(); totalWeight += lp.weight; - - if (heightMode == MeasureSpec.EXACTLY && lp.height == 0 && lp.weight > 0) { + + final boolean fillExcessSpace = lp.weight > 0; + final boolean hasZeroHeight = lp.height == 0; + if (heightMode == MeasureSpec.EXACTLY && fillExcessSpace && hasZeroHeight) { // Optimization: don't bother measuring children who are going to use // leftover space. These views will get measured again down below if // there is any leftover space. @@ -731,12 +733,12 @@ public class LinearLayout extends ViewGroup { mTotalLength = Math.max(totalLength, totalLength + lp.topMargin + lp.bottomMargin); skippedMeasure = true; } else { - final boolean fillExcessSpace = lp.height == 0 && lp.weight > 0; - if (fillExcessSpace) { - // heightMode is either UNSPECIFIED or AT_MOST, and this - // child wanted to stretch to fill available space. - // Translate that to WRAP_CONTENT so that it does not end up - // with a height of 0. + if (fillExcessSpace && hasZeroHeight) { + // The LinearLayout's heightMode is either UNSPECIFIED or + // AT_MOST, and this child wanted to stretch to fill + // available space. Translate the explicit height of 0 to + // WRAP_CONTENT so that we can measure the view's ideal + // height. lp.height = LayoutParams.WRAP_CONTENT; } @@ -751,7 +753,11 @@ public class LinearLayout extends ViewGroup { final int childHeight = child.getMeasuredHeight(); if (fillExcessSpace) { usedExcessSpace += childHeight; - lp.height = 0; + + // Restore original layout height. + if (hasZeroHeight) { + lp.height = 0; + } } final int totalLength = mTotalLength; @@ -1047,8 +1053,10 @@ public class LinearLayout extends ViewGroup { child.getLayoutParams(); totalWeight += lp.weight; - - if (widthMode == MeasureSpec.EXACTLY && lp.width == 0 && lp.weight > 0) { + + final boolean fillExcessSpace = lp.weight > 0; + final boolean hasZeroWidth = lp.width == 0; + if (widthMode == MeasureSpec.EXACTLY && fillExcessSpace && hasZeroWidth) { // Optimization: don't bother measuring children who are going to use // leftover space. These views will get measured again down below if // there is any leftover space. @@ -1075,12 +1083,12 @@ public class LinearLayout extends ViewGroup { skippedMeasure = true; } } else { - final boolean fillExcessSpace = lp.width == 0 && lp.weight > 0; - if (fillExcessSpace) { - // widthMode is either UNSPECIFIED or AT_MOST, and this - // child wanted to stretch to fill available space. - // Translate that to WRAP_CONTENT so that it does not end up - // with a width of 0. + if (fillExcessSpace && hasZeroWidth) { + // The LinearLayout's widthMode is either UNSPECIFIED or + // AT_MOST, and this child wanted to stretch to fill + // available space. Translate the explicit height of 0 to + // WRAP_CONTENT so that we can measure the view's ideal + // width. lp.width = LayoutParams.WRAP_CONTENT; } @@ -1095,7 +1103,11 @@ public class LinearLayout extends ViewGroup { final int childWidth = child.getMeasuredWidth(); if (fillExcessSpace) { usedExcessSpace += childWidth; - lp.width = 0; + + // Restore the original layout width. + if (hasZeroWidth) { + lp.width = 0; + } } if (isExactly) { |