android:drawableStart在图形布局上显示图像,但在模拟器或物理设备中不显示

时间:2013-12-27 10:26:09

标签: android android-button android-drawable

我相信标题总结得很好。我在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>

这是我所看到的图像。第一个按钮显示我想要的内容以及图形布局显示的内容。第二个按钮是物理设备上或模拟器执行时出现的按钮。

enter image description here

0 个答案:

没有答案