voglio fare uno stile tasto su Android con due colori di sfondo, come ad esempio la seguente immagine:Android: pulsante con due colori di sfondo
http://i.stack.imgur.com/ExKXl.png
è possibile fare con le risorse disegnabili? Sto cercando una soluzione su http://developer.android.com/guide/topics/resources/drawable-resource.html ma nessuno di questi può avere due colori.
C'è un modo?
[Modifica della risposta]
La soluzione era quella di creare un <layer-list>
con gli oggetti e ogni <item>
ha uno <shape>
. Il codice è soffietto (il pulsante intera ha un'altezza 32DP così ho usato mezza altezza per ogni colore):
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- Top color -->
<item android:bottom="16dp">
<shape android:shape="rectangle">
<solid android:color="#FF0000" /> <!-- RED -->
</shape>
</item>
<!-- Bottom color -->
<item android:top="16dp">
<shape android:shape="rectangle">
<solid android:color="#00FF00" /> <!-- GREEN -->
</shape>
</item>
</layer-list>
Ma ho avuto un altro problema, stavo cercando di mettere gli angoli su ogni forma. Ho provato a mettere android:topLeftRadius
e android:topRightRadius
sulla prima forma e android:bottomLeftRadius
e android:bottomRightRadius
sulla seconda forma ma non mi ha mostrato gli angoli! Quindi la soluzione era usare android:radius
(tutti gli 8 angoli diventavano arrotondati, dannazione!) E mettere altri due oggetti per superare gli angoli extra. Alla fine l'XML è così:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- Top color with corner -->
<item android:bottom="16dp">
<shape android:shape="rectangle">
<corners android:radius="5dp" /> <!-- It´s obligatory, It didn´t work only with android:topLeftRadius and android:topRightRadius -->
<solid android:color="#FF0000" /> <!-- RED Color-->
</shape>
</item>
<!-- Takes off the center corner -->
<item android:top="8dp" android:bottom="8dp">
<shape android:shape="rectangle">
<solid android:color="#FF0000" /> <!-- RED Color-->
</shape>
</item>
<!-- Bottom color with corner -->
<item android:top="16dp">
<shape android:shape="rectangle">
<corners android:radius="5dp" /> <!-- It´s obligatory, It didn´t work only with android:bottomLeftRadius and android:bottomRightRadius -->
<solid android:color="#00FF00" /> <!-- GREEN Color -->
</shape>
</item>
<!-- Takes off the center corner -->
<item android:top="16dp" android:bottom="8dp">
<shape android:shape="rectangle">
<solid android:color="#00FF00" /> <!-- GREEN Color -->
</shape>
</item>
</layer-list>
Ora funziona, grazie a tutti!
possibile duplicato di [? Sfondo fasciato con due colori] (http://stackoverflow.com/questions/8727238/banded-background-with-two-colors) –