我相信标题总结得很好。我在RelativeLayout中有一个Button。我的目标是在所述文本的左侧同时包含文本和小叶图像,因为我使用了android:drawableStart
。这让我感到困惑:图形布局确实显示了图像,但是当运行模拟器时,按钮显示没有图像。我也尝试过不同版本的物理设备,同样的故事。
我不知道出了什么问题。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center"
android:background="@drawable/background" >
<Button
android:id="@+id/neverMind"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/button_neverMind"
android:textColor="#E4F5ED"
android:background="@drawable/button_shape_shadow"
android:layout_centerHorizontal="true"
android:drawablePadding="5dp"
android:drawableStart="@drawable/button_leaf"
android:onClick="finish"/>
</RelativeLayout>
我应用以下xml来设置按钮样式:(标题为button_shape_shadow.xml)
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true">
<shape android:shape="rectangle">
<corners
android:bottomRightRadius="10dp"
android:bottomLeftRadius="10dp"
android:topLeftRadius="10dp"
android:topRightRadius="10dp"/>
<solid android:color="#3D6652" />
<padding android:bottom="10dp" android:left="10dp" android:right="10dp"
android:top="10dp" />
</shape>
</item>
<item>
<layer-list>
<item android:right="6dp" android:top="6dp">
<shape android:shape="rectangle">
<corners
android:bottomRightRadius="8dp"
android:bottomLeftRadius="8dp"
android:topLeftRadius="8dp"
android:topRightRadius="8dp"/>
<solid android:color="#3D6652" />
</shape>
</item>
<item android:bottom="2dp" android:left="2dp">
<shape>
<gradient android:angle="270" android:endColor="#87D1AC"
android:startColor="#62A382" />
<stroke android:width="3dp" android:color="#62A382" />
<corners
android:bottomRightRadius="10dp"
android:bottomLeftRadius="10dp"
android:topLeftRadius="10dp"
android:topRightRadius="10dp"/>
<padding android:bottom="10dp" android:left="10dp" android:right="10dp"
android:top="10dp" />
</shape>
</item>
</layer-list>
</item>
这是我所看到的图像。第一个按钮显示我想要的内容以及图形布局显示的内容。第二个按钮是物理设备上或模拟器执行时出现的按钮。