如何在安卓中更改自定义spinner的样式

6

我的观点是这样的,我正在使用自定义适配器来为下拉列表创建Spinner。

我从这个链接设计了我的Spinner http://rimpv.blogspot.in/2013/05/bind-spinner-dropdown-in-android.html

@Override
public View getView(int position, View convertView, ViewGroup parent) {
            TextView v = new TextView(getApplicationContext());
            v.setTextColor(Color.BLACK);
            v.setText(data.get(position).name);
            return v;
        }

enter image description here

但我希望显示为这样 enter image description here

如何在自定义下拉列表中实现?感谢您的帮助。


你能展示一下你是如何为Spinner设置适配器的吗? - Padma Kumar
http://rimpv.blogspot.in/2013/05/bind-spinner-dropdown-in-android.html - stackoverflow
请分享如何做到这一点,我有相同的情景。 - Sulabh Gajjar
我没有找到合适的答案,所以不接受任何答案。 - stackoverflow
5个回答

2

编辑3

这些示例只是从头开始的,现在没有IDE来测试。

如果您不需要自定义适配器,可以使用标准ArrayAdapter进行操作。然后为您的适配器设置dropDownViewResource。

public class Main extends Activity {

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    this.setContentView(R.layout.main);
    Spinner s = (Spinner) this.findViewById(R.id.spinner);

    ArrayList<String> list = new ArrayList<String>();
    list.add("Germany");
    list.add("USA");
    list.add("Nairobi");
    list.add("Japan");

    ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
    android.R.layout.simple_spinner_item, list);
    adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

    s.setAdapter(adapter);

    s.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
        public void onItemSelected(AdapterView<?> parent,
            View view, int pos, long id) {

            Toast.makeText(getApplicationContext(),
                    "CLICKED:"+parent.getItemAtPosition(pos).toString(),
                    Toast.LENGTH_LONG).show();
        }

        public void onNothingSelected(AdapterView parent) {
          // Do nothing.
        }
    });
}

如果您需要自定义适配器,那么除了构建自己的下拉列表项布局之外,没有其他选择:
构建您的main.xml。
   <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
      android:orientation="vertical"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
    >
   <Spinner 
      android:drawSelectorOnTop="true"
      android:id="@+id/example_spinner" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content"  > 
   </Spinner>
  </LinearLayout>

构建您的Spinner项目xml: spinner_item.xml:
    <LinearLayout 
      xmlns:android="http://schemas.android.com/apk/res/android"
       android:id="@+id/spinner_item_linear_layout" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content"
       android:orientation=”vertical”>


    <TextView        
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content "
      android:id="@+id/spinner_textView" >        
    </TextView>

    <RadioButton
      android:layout_width=”wrap_content”
      android:layout_height=”wrap_content”
      android:id=”@+id/spinner_radio_button” >
   </RadioButton>

 </LinearLayout>

定义一个字符串数组并输入一些内容,创建自定义适配器并将适配器设置到您的下拉列表中。
    public class CustomSpinnerExample extends Activity {


  String []countries ={"Germany","USA","Nairobi","Japan"};

    @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    Spinner mySpinner = (Spinner)findViewById(R.id.example_spinner);
    mySpinner.setAdapter(new CustomAdapter(this, R.layout.spinner_item, countries));
   }


    public class CustomAdapter extends ArrayAdapter<String>
   {

        public CustomAdapter(Context context, int resourceId,
                    String[] objects) {
              super(context, resourceId, objects);
              // TODO Auto-generated constructor stub
        }
        @Override
     public View getDropDownView(int position, View convertView,ViewGroup parent) {
        return getCustomView(position, convertView, parent);
     }

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

    public View getCustomView(int position, View convertView, ViewGroup parent) {

        LayoutInflater inflater=getLayoutInflater();
        View row=inflater.inflate(R.layout.spinner_item, parent, false);
        TextView label=(TextView)row.findViewById(R.id.spinner_textView);
         label.setText(countries[position]);


        RadioButton radioButton    =(RadioButton)row.findViewById(R.id.spinner_radio_button);
       radioButton.setOnClickListener(new OnClickListener(){

   public void onClick(View v){

Toast.makeText(CustomAdapter.this,”CLICKED:”+label.getText(),Toast.LENGTH_LONG).show();

  }
    });

        return row;
        }

   }
}

我已经使用这个链接中的代码编写了我的程序,请使用它来帮助我。http://rimpv.blogspot.in/2013/05/bind-spinner-dropdown-in-android.html - stackoverflow
请设置dropDownViewResource,如果您使用了您发布的示例。 - Opiatefuchs
是的,现在再看一遍edit2...我现在无法测试它,必须等到今晚如果edit2不起作用。 - Opiatefuchs
所以,现在最后,这里有另一个例子。我认为你必须从你的例子中解脱出来,开始一个新的例子。这些都是非常基础的,关于旋转器和适配器还有很多东西需要学习。把这个例子作为一个起点,继续阅读你能找到的所有相关内容。 - Opiatefuchs

2
你可以使用源代码创建一个新的 "doubleline_spinner.xml"。
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerDropDownItemStyle"
android:singleLine="false"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:ellipsize="none" 
android:textSize="15dp"

/>

将其添加到您的旋转器中。
        ArrayAdapter<CharSequence> PolarityAAdapter = ArrayAdapter.createFromResource(this,
        R.array.polarity_arrays,android.R.layout.simple_spinner_item);
        PolarityAAdapter.setDropDownViewResource(R.layout.doubleline_spinner);
        PolarityAspinner.setAdapter(PolarityAAdapter);

0

这是 getDropDownView

@Override
public View getDropDownView(int position, View convertView, ViewGroup parent) {

    LayoutInflater inflater = (LayoutInflater) mContext
            .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    if (convertView == null)
        convertView = inflater.inflate(R.layout.simple_spinner_dropdown_item, null, true);

    CheckedTextView text = (CheckedTextView) convertView.findViewById(R.id.text1);

    text.setText("TEXT");

    return convertView;
}

在创建适配器之后添加这个

myAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

0
你可以看一下这个简单的教程,类似于this。但我非常确定你不想这样做。
所以看一下如何使用布局制作自定义适配器,教程是针对listView的,但对于spinner来说,操作是相同的。
你可以创建一个包含TextViewCheckBox的自定义布局,就像这样:
<LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android&#8221;
android:id=”@+id/linearLayout1″
android:layout_width=”fill_parent”
android:layout_height=”fill_parent” >

<CheckBox
android:id=”@+DropDownList/checkbox”
android:layout_width=”wrap_content”
android:layout_height=”wrap_content” />

<TextView
android:id=”@+DropDownList/SelectOption”
android:layout_width=”wrap_content”
android:layout_height=”wrap_content” />

</LinearLayout>

而在你的函数中:

@Override
    public int getItemViewType(int position) {
        return R.layout.YourLayout;
    }

两个链接都没有帮到我。 - stackoverflow
第二个链接中有一个方法: public View getView(int position, View convertView, ViewGroup parent){},它与您的代码中的适配器中的相同方法,在这个函数中,您可以为您的微调器的每一行做任何您想要的事情。只需更改您的方法: @Override public int getItemViewType(int position) { return android.R.layout.simple_spinner_dropdown_item; } 以返回您的自定义布局即可。 - vmathieu
我看到了,但我需要选择选项,在你的链接中没有显示给我选择选项。 - stackoverflow
使用自定义适配器,您可以在每一行中实现您想要的功能。 - vmathieu

0

看看这个教程

你可以更改 spinner 的背景图片:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <Spinner
    android:drawSelectorOnTop="true"
    android:id="@+id/spinner1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:prompt="@string/select">
    </Spinner>
</LinearLayout>

通过在您的下拉列表中添加以下代码:

android:src="@drawable/your_image"

您可以将图片添加到其中。这样它看起来会更好。
<Spinner
android:drawSelectorOnTop="true"
android:id="@+id/spinner1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:src="@drawable/your_image"
android:prompt="@string/select">
</Spinner>

我不想添加图片。 - stackoverflow
如果您不想使用图像,请尝试此教程:http://vimaltuts.com/android-tutorial-for-beginners/android-spinner-control-example - Alex.Zaiats
我已经尝试过了,但这不起作用,你有仔细阅读我的问题吗? - stackoverflow

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接