私の場合、スピナー項目に標準レイアウトを使用し、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;
}
}
次に、スピナー用のアダプターをセットアップします。
mPaymentTypeArrayAdapter = new PaymentTypeArrayAdapter(getContext());
setAdapter(mPaymentTypeArrayAdapter);
このアプローチの鍵は、ラベルにsetCompoundDrawablesWithIntrinsicBoundsを使用することでした