我在ImageView
中有一个<layer-list>
和一个/res/drawable/
。这是图层列表:
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item>
<!-- This is a 24dp x 24dp PNG -->
<bitmap android:src="@drawable/ic_secondary_arrow"
android:gravity="center"/>
</item>
<item>
<shape android:shape="oval">
<stroke android:color="@color/icon_primary_background"
android:width="2dp"/>
<solid android:color="@android:color/transparent" />
</shape>
</item>
</layer-list>
ImageView没什么特别的:
<ImageView
android:id="@+id/arrow"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_margin="16dp"/>
使用src
或setImageDrawable(int)
指向图层列表时,center
似乎被忽略(或者至少这不是我想要的行为):
我想将其显示如下。这可以使用background
(或setBackground(Drawable)
)代替src
:
我坚持的原因是因为setBackground(Drawable)
仅限于API16 +,因此我不会限制我的观众。
那么,我错过了什么?
编辑,如下所示@pskink,我错过了setBackgroudDrawable(Drawable)
。但是,这仍是一个偶然的问题。我真的想知道在这种情况下src
和background
(以及各自的方法)的不同行为背后的原因是什么。
答案 0 :(得分:0)
似乎ImageView
以相同的尺寸绘制两个项目。你可以像这样在你的drawable中添加“padding”:
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:top=“16dp” android:left=“16dp” android:right="16dp" android:bottom="16dp">
<!-- This is a 24dp x 24dp PNG -->
<bitmap android:src="@drawable/ic_secondary_arrow"
android:gravity="center"/>
</item>
<item>
<shape android:shape="oval">
<stroke android:color="@color/icon_primary_background"
android:width="2dp"/>
<solid android:color="@android:color/transparent" />
</shape>
</item>
</layer-list>