注:参考http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0105/2264.html
Spinner
==>
Spinner是ViewGroup的间接子类,因此也可作为容器使用。
常用属性:
android:prompt——设置该列表框选择框的提示信息
android:entries——使数组资源设置该下拉列表框的列表项目
注意:在使用Spinner时,如果可预先指导列表框内容信息,则不需要编写代码,只需要为Spinner指定 android:entries 属性即可实现一个下拉列表框。
实例一:最简单的使用方式——通过资源文件绑定数据源
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="books">
<item>大话设计模式</item>
<item>大话android</item>
<item>java 高级编程</item>
</string-array>
</resources> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".IndexActivity" > <Spinner
android:id="@+id/spcontent"
android:entries="@array/books"
android:layout_width="match_parent"
android:layout_height="wrap_content" /> </RelativeLayout>
注意:需要为values文件夹下添加arrays.xml文件,如下图:
注意:可通过处理setOnItemSelectedListener添加Spinner选择事件...
选择事件处理
package com.example.myspinner; import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.Spinner;
import android.widget.Toast; public class IndexActivity extends Activity
{
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.index); Spinner spinner = (Spinner) this.findViewById(R.id.spcontent);
spinner.setOnItemSelectedListener(new SpinnerSelectLintener()); } private class SpinnerSelectLintener implements OnItemSelectedListener
{
@Override
public void onItemSelected(AdapterView<?> parent, View view,
int position, long id)
{
String[] books = getResources().getStringArray(R.array.books);
String value = "选择了:" + books[position];
Toast.makeText(IndexActivity.this, value, 3000).show();
} @Override
public void onNothingSelected(AdapterView<?> parent)
{
}
} @Override
public boolean onCreateOptionsMenu(Menu menu)
{
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.index, menu);
return true;
} }
实例二 ——
通过ArrayAdapter绑定数据源
package com.example.myspinner2; import android.os.Bundle;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Toast;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.Spinner; @SuppressLint("ShowToast")
public class MainActivity extends Activity
{
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); Spinner spinner = (Spinner) this.findViewById(R.id.spcontent);
// 建立数据源
String[] mItems = getResources().getStringArray(R.array.books);
// 建立Adapter并且绑定数据源
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
android.R.layout.simple_spinner_item, mItems);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
// 绑定 Adapter到控件
spinner.setAdapter(adapter); spinner.setOnItemSelectedListener(new OnItemSelectedListener()
{
@Override
public void onItemSelected(AdapterView<?> parent, View view,
int position, long id)
{
String[] books = getResources().getStringArray(R.array.books);
String value = "选择了:" + books[position];
Toast.makeText(MainActivity.this, value, 3000).show();
} @Override
public void onNothingSelected(AdapterView<?> parent)
{
}
});
} @Override
public boolean onCreateOptionsMenu(Menu menu)
{
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
} }
运行效果如下:
注意:
1.第二个参数是Spinner未展开菜单时Spinner的默认样式,android.R.layout.simple_spinner_item是系统自带的内置布局
2.通过如下设置可以更改Spinner展开以及显示样式
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_checked, mItems);
adapter.setDropDownViewResource(android.R.layout.simple_list_item_checked);
3.如果不设置adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)会怎样呢?
会造成未展开的sipnner和展开的菜单都是一种布局样式
4.其实simple_spinner_item和simple_spinner_dropdown_item两者的名字正好反映了他们的区别。一个应用于下拉一个应用于Spinner本身。
5.Spinner的菜单显示方式
它有两种显示形式,一种是下拉菜单,一种是弹出框,菜单显示形式是spinnerMode属性决定的:
1
2
|
android:spinnerMode= "dropdown" android:spinnerMode= "dialog" |
在android2.3上没有这个属性,系统默认将Spinner弹出菜单显示成dialog。
Theme.Light和Theme.Holo.Light下Spinner在不同模式下的效果对比图如下所示:
Spinner支持的XML属性:
1. entries: 直接在xml布局文件中绑定数据源(可以不设置,即可以在Activity中动态绑定)
2.spinnerMode: Spinner的显示形式
3.android:prompt="@string/app_name"——在Spinner弹出选择对话框的时候对话框的标题
实例三——使用自定义Adapter
注意:使用自定义Adapter需要添加子布局文件;需要添加Adapter泛型
子布局文件==》
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" > <TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:drawableLeft="@drawable/tjcl_1"
android:paddingRight="8dip"
android:paddingTop="8dip"
android:textSize="20sp" /> <TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="8dip"
android:paddingTop="8dip"
android:textSize="20sp" /> </LinearLayout> 自定义Adapter以及实现==>
package com.example.myspinner3; import java.util.ArrayList;
import java.util.List; import android.os.Bundle;
import android.app.Activity;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Spinner;
import android.widget.TextView; public class MainActivity extends Activity
{
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); // 初始化控件
Spinner spinner = (Spinner) findViewById(R.id.spcontent);
// 建立数据源
List<Person> persons = new ArrayList<Person>();
persons.add(new Person("猪八戒", "上海 "));
persons.add(new Person("王麻子", "上海 "));
persons.add(new Person("姜子牙", "北京"));
persons.add(new Person("王婆子", "广州 "));
// 建立Adapter绑定数据源
MyAdapter adapter = new MyAdapter(this, persons);
// 绑定Adapter
spinner.setAdapter(adapter);
} public class Person
{
private String personName;
private String personAddress; public Person(String personName, String personAddress)
{
super();
this.personName = personName;
this.personAddress = personAddress;
} public String getPersonName()
{
return personName;
} public void setPersonName(String personName)
{
this.personName = personName;
} public String getPersonAddress()
{
return personAddress;
} public void setPersonAddress(String personAddress)
{
this.personAddress = personAddress;
} } public class MyAdapter extends BaseAdapter
{
private List<Person> personList;
private Context mContext; public MyAdapter(Context pContext, List<Person> pList)
{
this.mContext = pContext;
this.personList = pList;
} @Override
public int getCount()
{
return personList.size();
} @Override
public Object getItem(int position)
{
return personList.get(position);
} @Override
public long getItemId(int position)
{
return position;
} /**
* 下面是重要代码
*/
@Override
public View getView(int position, View view, ViewGroup parent)
{
LayoutInflater layoutinflater = LayoutInflater.from(mContext);
view = layoutinflater.inflate(R.layout.itemspinner, null);
if (view != null)
{
TextView tv1 = (TextView) view.findViewById(R.id.textView1);
TextView tv2 = (TextView) view.findViewById(R.id.textView2); tv1.setText(personList.get(position).getPersonName());
tv2.setText(personList.get(position).getPersonAddress());
}
return view;
}
} @Override
public boolean onCreateOptionsMenu(Menu menu)
{
getMenuInflater().inflate(R.menu.main, menu);
return true;
} }
实现效果如下图所示:
LayoutInflater——参考http://www.cnblogs.com/top5/archive/2012/05/04/2482328.html
==>
LayoutInflater是用来找res/layout/下的xml布局文件,并且实例化;而findViewById()是找xml布局文件下的具体widget控件(如Button、TextView等)。
具体作用: