W moim przypadku właśnie używany standardowy układ przedmiotów spinner i zastąpić tylko trochę się ArrayAdapter.
private class PaymentTypeArrayAdapter extends ArrayAdapter<PaymentType> {
public PaymentTypeArrayAdapter(Context context) {
super(context, android.R.layout.simple_spinner_item);
addAll(PaymentType.getPaymentTypes());
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
TextView label = (TextView) super.getView(position, convertView, parent);
PaymentType paymentType = getItem(position);
label.setText(paymentType.getStringResourceId());
label.setCompoundDrawablesWithIntrinsicBounds(0, 0, paymentType.
getImageResourceId(), 0);
return label;
}
@Override
public View getDropDownView(int position, View convertView, ViewGroup parent) {
TextView label = (TextView) super.getDropDownView(position, convertView, parent);
PaymentType paymentType = getItem(position);
label.setText(paymentType.getStringResourceId());
label.setCompoundDrawablesWithIntrinsicBounds(0, 0, paymentType.
getImageResourceId(), 0);
return label;
}
}
Następnie skonfigurować adapter dla turbinki:
mPaymentTypeArrayAdapter = new PaymentTypeArrayAdapter(getContext());
setAdapter(mPaymentTypeArrayAdapter);
W tym podejściu kluczem było wykorzystanie setCompoundDrawablesWithIntrinsicBounds dla etykiety
chcesz zmienić tło turbinki? –
http://stackoverflow.com/questions/3609231/how-is-it-possible-to-create-a-spinner-with-images-instead-of-text –