Android 如何创建带有图像而不是文本的微调器?

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/3609231/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-08-20 10:58:10  来源:igfitidea点击:

How is it possible to create a spinner with images instead of text?

androidspinner

提问by thpoul

Given the code bellow, is it possible to have images instead of text in the array planets?

鉴于下面的代码,是否可以在阵列行星中使用图像而不是文本?

    Spinner s = (Spinner) findViewById(R.id.spinner);    
    ArrayAdapter adapter = ArrayAdapter.createFromResource(            
            this, R.array.planets, android.R.layout.simple_spinner_item);    
    adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);    
    s.setAdapter(adapter);

and

    <string name="planet_prompt">Choose a planet</string>
    <string-array name="planets">        
        <item>Mercury</item>
        <item>Venus</item>
        <item>Earth</item>        
        <item>Mars</item>        
        <item>Jupiter</item>        
        <item>Saturn</item>        
        <item>Uranus</item>        
        <item>Neptune</item>    
    </string-array>    

采纳答案by Vicky Kapadia

Yes it is look at the code below:

是的,看下面的代码:



array of data

// stores the image database icons
    private static Integer[] imageIconDatabase = { R.drawable.ball,
            R.drawable.catmouse, R.drawable.cube, R.drawable.fresh,
            R.drawable.guitar, R.drawable.orange, R.drawable.teapot };

    // stores the image database names
    private String[] imageNameDatabase = { "ball", "catmouse", "cube", "fresh",
            "guitar", "orange", "teapot" };


creating List of hashmaps

创建哈希映射列表

private void initializeImageList() {
        // TODO Auto-generated method stub
        for (int i = 0; i < imageNameDatabase.length; i++) {
            map = new HashMap<String, Object>();

            map.put("Name", imageNameDatabase[i]);
            map.put("Icon", imageIconDatabase[i]);
            spinnerList.add(map);
        }
        ImageView imageView = new ImageView(this);
        imageView.setBackgroundResource((spinnerList.get(0).get("Icon"));
        spinnerList.get(0).get("Name");
    }


assigning spinner to adapter

将微调器分配给适配器

public void createAddDialog() {
        // TODO
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.list_editoradd_dialog);

        Spinner spin = (Spinner) findViewById(R.id.spinnerAddImageList);
        CustomSpinnerAdapter adapter = new CustomSpinnerAdapter(this,
                spinnerData, R.layout.spinner_view, new String[] { "Name",
                        "Icon" }, new int[] { R.id.imageNameSpinner,
                        R.id.imageIconSpinner });
        spin.setAdapter(adapter);
    }


the adapter used above is as given below..

上面使用的适配器如下所示..

package com.tcs.CustomListViewGeneration;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.SimpleAdapter;
import android.widget.TextView;

class CustomSpinnerAdapter extends SimpleAdapter {

    LayoutInflater mInflater;
    private List<? extends Map<String, ?>> dataRecieved;

    public CustomSpinnerAdapter(Context context, List<? extends Map<String, ?>> data,
            int resource, String[] from, int[] to) {
        super(context, data, resource, from, to);
        dataRecieved =data;
        mInflater=LayoutInflater.from(context);
    }

    @SuppressWarnings("unchecked")
    public View getView(int position, View convertView, ViewGroup parent) {
        if (convertView == null) {
            convertView = mInflater.inflate(R.layout.spinner_view,
                    null);
        }
    //  HashMap<String, Object> data = (HashMap<String, Object>) getItem(position);
        ((TextView) convertView.findViewById(R.id.imageNameSpinner))
                .setText((String) dataRecieved.get(position).get("Name"));
        ((ImageView) convertView.findViewById(R.id.imageIconSpinner))
                .setBackgroundResource(dataRecieved.get(position).get("Icon")));
        return convertView;
    }
}


回答by koljaTM

I just needed a super easy solution for a fixed set of images in a spinner, so I did this:

我只需要一个超级简单的解决方案来处理微调器中的一组固定图像,所以我这样做了:

public class SimpleImageArrayAdapter extends ArrayAdapter<Integer> {
private Integer[] images;

public SimpleImageArrayAdapter(Context context, Integer[] images) {
    super(context, android.R.layout.simple_spinner_item, images);
    this.images = images;
}

@Override
public View getDropDownView(int position, View convertView, ViewGroup parent) {
    return getImageForPosition(position);
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    return getImageForPosition(position);
}

private View getImageForPosition(int position) {
        ImageView imageView = new ImageView(getContext());
        imageView.setBackgroundResource(images[position]);
        imageView.setLayoutParams(new AbsListView.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT));
        return imageView;
}

}

}

And then in the code you can just use it like this:

然后在代码中你可以像这样使用它:

    SimpleImageArrayAdapter adapter = new SimpleImageArrayAdapter(context, 
        new Integer[]{R.drawable.smiley1, R.drawable.smiley2, R.drawable.smiley3, R.drawable.smiley4, R.drawable.smiley5});
    spinner.setAdapter(adapter);

回答by Luke

Not sure if anyone is still using Spinners in 2020, but here's a Kotlin version of this solution (https://stackoverflow.com/a/22216375/6007104):

不确定是否有人在 2020 年仍在使用 Spinner,但这是此解决方案的 Kotlin 版本(https://stackoverflow.com/a/22216375/6007104):

class MySpinnerAdapter(context: Context, images: Array<Int>) :
    ArrayAdapter<Int>(context, android.R.layout.simple_spinner_item, images) {

    override fun getDropDownView(position: Int, convertView: View?, parent: ViewGroup) =
        getImageForPosition(position)

    override fun getView(position: Int, convertView: View?, parent: ViewGroup) =
        getImageForPosition(position)

    private fun getImageForPosition(position: Int) = ImageView(context).apply {
        setBackgroundResource(getItem(position)!!)
        layoutParams = ViewGroup.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)
    }
}