Questo è un molto tardi "me too", ma dopo essere venuto a questa e ad altre domande alla ricerca di una soluzione, ho trovato un semplice, elegante soluzione del mio.
Un altro question si è lamentato che lo sfondo trasparente della loro immagine non era cliccabile. Se questo è un problema, anche questo sembra aggirarlo.
Ecco il tasto:
<ImageButton
android:id="@+id/arrowUp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/arrow_up"
android:background="@drawable/clear_button_background" />
Le linee interessate sono le ultime due. "@drawable/arrow_up"
è alcuni stati del pulsante in file * .png definiti in un file .xml drawable * come questo:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:state_pressed="true"
android:drawable="@drawable/tri_up_blue" /> <!-- pressed -->
<item android:state_selected="true"
android:drawable="@drawable/tri_up_blue" /> <!-- selected -->
<item android:state_focused="true"
android:drawable="@drawable/tri_up_blue" /> <!-- focused -->
<item android:drawable="@drawable/tri_up_green" /> <!-- default -->
</selector>
Basta il pulsante di base. Niente di speciale. E "@drawable/clear_button_background"
è proprio questo:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<solid android:color="@android:color/transparent"/>
<size android:width="20dp" android:height="30dp" />
</shape>
L'altezza e la larghezza qui sono l'area cliccabile, ridimensionare, se necessario. Puoi riutilizzarlo per tutti i pulsanti di cui hai bisogno in una singola vista, a differenza dell'assurdamente dettagliato TouchDelegate. Nessun ascoltatore aggiuntivo. Non aggiunge nessuna vista o gruppo alla tua gerarchia e non dovrai fare confusione con padding e margini tutto il giorno.
Semplice. Elegante.
Funziona solo in modo ordinato. Per renderlo pienamente funzionante è necessario rendere il pulsante setClickable (false), altrimenti cliccando sul pulsante stesso non si evidenzia quando ottiene il suo stato dal genitore che non viene cliccato a questo punto. Una volta che il pulsante non è cliccabile, non è necessario impostare un listener onClick su di esso. –