Only verify resolved theme attributes

Bug: 19962473
Change-Id: I62eb2faea7b09fd483194b41e815179cb2141fcb
This commit is contained in:
Alan Viverette
2015-03-27 10:57:34 -07:00
parent 9aaaa1ebb3
commit ee7c65d539

View File

@@ -721,7 +721,7 @@ public class BitmapDrawable extends Drawable {
final TypedArray a = obtainAttributes(r, theme, attrs, R.styleable.BitmapDrawable);
updateStateFromTypedArray(a);
verifyState(a);
verifyRequiredAttributes(a);
a.recycle();
// Update local properties.
@@ -733,11 +733,13 @@ public class BitmapDrawable extends Drawable {
*
* @throws XmlPullParserException if any required attributes are missing
*/
private void verifyState(TypedArray a) throws XmlPullParserException {
private void verifyRequiredAttributes(TypedArray a) throws XmlPullParserException {
// If we're not waiting on a theme, verify required attributes.
final BitmapState state = mBitmapState;
if (state.mBitmap == null) {
if (state.mBitmap == null && (state.mThemeAttrs == null
|| state.mThemeAttrs[R.styleable.BitmapDrawable_src] == 0)) {
throw new XmlPullParserException(a.getPositionDescription() +
": <bitmap> requires a valid src attribute");
": <bitmap> requires a valid 'src' attribute");
}
}
@@ -759,7 +761,7 @@ public class BitmapDrawable extends Drawable {
final Bitmap bitmap = BitmapFactory.decodeResource(r, srcResId);
if (bitmap == null) {
throw new XmlPullParserException(a.getPositionDescription() +
": <bitmap> requires a valid src attribute");
": <bitmap> requires a valid 'src' attribute");
}
state.mBitmap = bitmap;