diff options
author | Alan Viverette <alanv@google.com> | 2015-06-17 14:09:53 -0700 |
---|---|---|
committer | Alan Viverette <alanv@google.com> | 2015-06-17 14:09:53 -0700 |
commit | 536652fe91d10e5baebe0f9ca5d7e21c88ae9d9e (patch) | |
tree | ccb15edc3a8c1b718121c519b2f85b0e2f88456c /graphics | |
parent | 15ce33873e2ca774a1fca666a05cc8ed79f327d7 (diff) | |
download | frameworks_base-536652fe91d10e5baebe0f9ca5d7e21c88ae9d9e.zip frameworks_base-536652fe91d10e5baebe0f9ca5d7e21c88ae9d9e.tar.gz frameworks_base-536652fe91d10e5baebe0f9ca5d7e21c88ae9d9e.tar.bz2 |
Resolve start/end insets in LayerDrawable.getIntrinsicWidth()
Bug: 21849185
Change-Id: If9b392d863e808d83a5d90bcc32df6cb9194cbdf
Diffstat (limited to 'graphics')
-rw-r--r-- | graphics/java/android/graphics/drawable/LayerDrawable.java | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/graphics/java/android/graphics/drawable/LayerDrawable.java b/graphics/java/android/graphics/drawable/LayerDrawable.java index 5c00a23..175db24 100644 --- a/graphics/java/android/graphics/drawable/LayerDrawable.java +++ b/graphics/java/android/graphics/drawable/LayerDrawable.java @@ -1537,8 +1537,23 @@ public class LayerDrawable extends Drawable implements Drawable.Callback { continue; } + // Take the resolved layout direction into account. If start / end + // padding are defined, they will be resolved (hence overriding) to + // left / right or right / left depending on the resolved layout + // direction. If start / end padding are not defined, use the + // left / right ones. + final int insetL, insetR; + final int layoutDirection = getLayoutDirection(); + if (layoutDirection == LayoutDirection.RTL) { + insetL = r.mInsetE == UNDEFINED_INSET ? r.mInsetL : r.mInsetE; + insetR = r.mInsetS == UNDEFINED_INSET ? r.mInsetR : r.mInsetS; + } else { + insetL = r.mInsetS == UNDEFINED_INSET ? r.mInsetL : r.mInsetS; + insetR = r.mInsetE == UNDEFINED_INSET ? r.mInsetR : r.mInsetE; + } + final int minWidth = r.mWidth < 0 ? r.mDrawable.getIntrinsicWidth() : r.mWidth; - final int w = minWidth + r.mInsetL + r.mInsetR + padL + padR; + final int w = minWidth + insetL + insetR + padL + padR; if (w > width) { width = w; } |