2016-07-15 9 views
0

Ich möchte ein Zeichen erstellen und verwenden Sie es als Hintergrund für meine Schaltflächen. Die Höhe des Schattens muss 18dip sein. Siehe das Bild.Android-Schaltfläche mit Schatten in Xml-Zeichen

This should be described in drawable xml

Ich habe es auf diese Weise versucht, aber es funktioniert nicht:

<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
    <item android:state_enabled="false"> 
     <layer-list> 
      <item android:gravity="bottom"> 
       <bitmap android:src="@drawable/shadow9path"/> // This is a 9-path picture 
      </item> 
      <item android:gravity="bottom" 
        android:bottom="18dp"> 
       <shape android:shape="rectangle"> 
        <size android:height="@dimen/..." /> 
        <corners android:radius="@dimen/..." /> 
        <solid android:color="@color/..." /> 
       </shape> 
      </item> 
     </layer-list> 
    </item> 
... 
</selector> 

EDIT: Der Schatten nur auf dem Boden der Taste sein soll. Der Button sollte also nicht mit dem Schatten gerundet werden. Ich brauche etwas wie eine zusammengesetzte Ansicht, die aus dem Knopf und dem Schatten darunter besteht.

+1

Dies könnte sein, was Sie für http://stackoverflow.com/questions/15333529/how-to- suchen provide-shadow-to-button – Rishi

+0

Leider ist nicht das, was ich Nebel suche. Der Schatten sollte nur auf der Unterseite der Schaltfläche sein. Ich werde die Frage aktualisieren. – Alex

+0

' // Dies ist ein 9-Pfad Bild. Wenn es ein ** 9 Patch ist, warum benutzt du' bitmap'? Sie sollten 'nine-patch' verwenden: https://developer.android.com/guide/topics/resources/drawable-resource.html –

Antwort

0

mich Diese Arbeit bilden, versuchen:

<item> 
    <layer-list> 
     <item android:right="10dp" android:top="10dp"> 
      <shape> 
       <corners android:radius="5dp" /> 
       <solid android:color="#D6D6D6" /> 
      </shape> 
     </item> 
     <item android:bottom="3dp" android:left="3dp"> 
      <shape> 
       <gradient android:angle="280" 
        android:endColor="#E2E2E2" android:startColor="#BABABA" /> 
       <stroke android:width="2dp" android:color="#BABABA" /> 
       <corners android:radius="5dp" /> 
       <padding android:bottom="10dp" android:left="10dp" 
        android:right="10dp" android:top="10dp" /> 
      </shape> 
     </item> 
    </layer-list> 
</item> 
0

dieses versuchen

<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
<item> 
    <layer-list> 
     <item android:right="5dp" android:top="5dp"> 
      <shape> 
       <corners android:radius="3dp" /> 
       <solid android:color="#D6D6D6" /> 
      </shape> 
     </item> 
     <item android:bottom="2dp" android:left="2dp"> 
      <shape> 
       <gradient android:angle="270" 
        android:endColor="#E2E2E2" android:startColor="#BABABA" /> 
       <stroke android:width="1dp" android:color="#BABABA" /> 
       <corners android:radius="4dp" /> 
       <padding android:bottom="10dp" android:left="10dp" 
        android:right="10dp" android:top="10dp" /> 
      </shape> 
     </item> 
</layer-list> 

</item> 

</selector>