web-dev-qa-db-ja.com

Androidでスピナーに画像を追加する方法

私が試したスピナーに画像を追加したい:

<Spinner
    Android:id="@+id/spinner1"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:background="@drawable/myImage" />

しかし、このコードを使用すると、スピナーの下矢印の表示が見えなくなります。その問題の解決方法を教えてください!!この画像のように正確にやりたい

enter image description here

15
Arshad Ali

/res/layout/row.xmlを作成します。各行のレイアウトを設定します。

  <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:layout_width="fill_parent"
    Android:layout_height="wrap_content"
    Android:orientation="horizontal">
    <ImageView
    Android:id="@+id/icon"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:src="@drawable/icon"/>
    <TextView
    Android:id="@+id/weekofday"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"/>
</LinearLayout>

Javaファイルにこのコードを

 Spinner mySpinner = (Spinner)findViewById(R.id.spinner);
  ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
    R.layout.row, R.id.weekofday, YourArrayHere);
  mySpinner.setAdapter(adapter);
16
Ram kiran

私の場合、スピナーアイテムの標準レイアウトを使用して、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 を使用することが重要でした