Spinner下拉列表的学习心得

来源:互联网 发布:孕妇装比较好的淘宝店 编辑:程序博客网 时间:2024/05/17 06:14

在android项目的过程中,使用到下拉列表控件,以前不是很熟悉,现在趁此机会好好学习,总结一下spinner在activity和fragment中的用法,供大家一块学习和自己日后的进步。
这里写图片描述
Spinner组件一共有两个,一个是本身的Spinner,一个是android.support.v7.widget.AppCompatSpinner,两者的区别在于v7内的Spinner是兼容低版本的,Spinner再高版本中才能使用的方法换了v7下的Spinner后可以一直兼容到2.1 (v7兼容到api7),初次之外两者的使用没有其他差别,推荐使用v7,保证效果在不同版本上都能显示.
spinner控件的使用步骤主要是分为以下几步:

  • 第一步:在对应的布局文件中添加spinner控件
<Spinner            android:id="@+id/spinner_location"            android:layout_width="wrap_content"            android:layout_height="35dp"/>

在布局文件中,宽度和高度可以根据自己的要求随意调整,下面还有布局文件中对于spinner组件中的相关属性。
a、 android:dropDownHorizontalOffset——spinnerMode=”dropdown”时,下拉的项目选择窗口在垂直方向相对于Spinner窗口的偏移量
对应的方法:

setDropDownVerticalOffset(int)

这个属性它必须是一个带有单位的浮点型尺寸值,如:”14.5sp”。有效的单位包括:px(像素)、dp(密度无关的像素)、sp(基于引用字体的尺寸来缩放的像素)、in(英寸)、mm(毫米)。
还可以引用一个资源(格式:@[package:]type:name)或者是包含这种类型值的主题属性(格式:?[package][type:]name)。
b、android:dropDownSelector——-用于设定spinnerMode=”dropdown”时列表选择器的显示效果,它可以用”@[+][package]:type:name”格式来引用另外的资源,或者是用”?[package:][type:]name”的格式来 应用主题属性,还可以是”#rgb”、”#argb”、”#rrggbb”、”aarrggbb”格式的颜色值。它对应的全局属性资源符号是dropDownSelector
c、android:dropDownWidth—–在spinnerMode=”dropdown”时,设定下拉框的宽度。这个属性可以是带有单位的浮点型的尺寸值,如:14.5sp。有效的单位包括:px(像素)、dp(密度无关的像素)、sp(基于引用字体的尺寸来缩放的像素)、in(英寸)、mm(毫米)。还可以引用一个资源(格式:@[package:]type:name)或者是包含这种类型值的主题属性(格式:?[package][type:]name)。
对应方法

setDropDownWidth(int)

还可以是下列常量之一:
fill_parent = -1,下拉框的宽度应该使用屏幕的宽度来设定。这个常量从API Level 8开始被废弃了,并且使用mach_parent常量来代替。
mach_parent = -1,下拉框的宽度应该使用屏幕的宽度来设定。在API Level 8中被引入。
wrap_content = -2,下拉框的宽度应该跟它的内容相适应
d、android:gravity——
这个属性用于设置当前选择的项目的对齐方式。
它必须是以下常量值之一或组合(用”|”符号分离)。
top = 0x30:把选择的对象放到它的容器的顶部,不改变它的尺寸。
bottom = 0x50:把选择的对象放到它的容器的底部,不改变它的尺寸。
left = 0x03:把选择的对象放到它的容器的左边,不改变它的尺寸。
right = 0x05:把选择的对象放到它的容器的右边,不改变它的尺寸。
center_vertical = 0x10:把选择的对象放到它的容器的垂直中心,不改变它的尺寸。
fill_vertical = 0x70:为了完全的填充它的容器,系统会根据需要来增加选择对象的垂直尺寸。
center_horizontal = 0x01:把选择的对象放到它的容器的水平中心,不改变它的尺寸。
fill_horizontal = 0x07:为了完全的填充它的容器,系统会根据需要来增加选择对象的水平尺寸。
center = 0x11:把选择的对象放到它的容器的垂直和水平中心,不改变它的尺寸。
fill = 0x77:为了完全的填充它的容器,系统会根据需要来增加选择对象的水平和垂直尺寸。
clip_vertical = 0x80:附加的可选设置,它可以设置容器内子对象的上下边缘裁剪它的容器边框。裁剪会基于垂直对齐的方式:顶部对齐的会裁剪底部边缘,底部对齐的会裁剪顶部边缘,不会上下边缘都裁剪。
clip_horizontal = 0x08:附加的可选设置,它可以设置容器内子对象的左右边缘裁剪它的容器边框。裁剪会基于水平对齐的方式:左对齐的会裁剪右边缘,右对齐的会裁剪左边缘,不会左右边缘都裁剪。
start = 0x00800003:把对象放到它的容器的开始位置,不改变它的尺寸。
end = 0x00800005:把对象放到它的容器的结束位置,不改变它的尺寸。
对应的全局属性资源符号是gravity。
注:Spinner对象是一个视窗对象容器,设置它的gravity属性时,只会改变容器内部子视窗对象的对齐方式,并不会改变子视窗内部内容的对齐方式
对应方法

setGravity(int)

e、android:popupBackground——-
在spinner=”dropdown”时,使用这个属性来设置下拉列表的背景。
可以使用”@[+][package:]type:name”格式来引用另外的资源,或者使用”?[package:][type:]name”格式来应 用主题属性,也可以使用”#rgb”、”#argb”、”#rrggbb”、”#aarrggbb”格式的颜色值
f、android:prompt——-当显示模式为dialog时生效,作用为显示dialog的标题内容
g、android:spinnerMode ——-显示模式 :popu和dialog两种
第二步、设置数据源和显示主题
下拉列表的android.R系统自带的xml样式,其中常见的有android.R.layout.simple_spinner_item,android.R.pinner_dropdown,详细可见(http://blog.csdn.net/a2012s/article/details/8372725),下面是具体的实现代码:

private Spinner spinner; private List<String>list;  protected void onCreate(Bundle savedInstanceState){        super.onCreate(savedInstanceState);        setContentView(R.layout.activity);        MyApplication.getInstance().addActivity(this);        list=new ArrayList<>();        list.add("北京");        list.add("上海");        list.add("深圳");        list.add("成都");         location=(EditText)view.findViewById(R.id.location);        spinner=(Spinner)view.findViewById(R.id.spinner_location);//绑定控件         //选取合适的适配器的样式        ArrayAdapter<String>adapter=new ArrayAdapter<String>(this,android.R.layout.simple_spinner_dropdown_item,list);        adapter.setDropDownViewResource(android.R.layout.simple_list_item_single_choice);        spinner.setAdapter(adapter);//添加适配器        //添加适配器选择动作        spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener()        {            @Override            public void onItemSelected(AdapterView<?> parent, View view, int position, long id)            {                //下拉列表中的事件选中后反应                location.setText("1");            }            @Override            public void onNothingSelected(AdapterView<?> parent) {            //未选中事件响应            }        });} 

第三步、添加适配器,并添加响应事件
Spinner数据源于xml数组,其实用的最多的还是通过adapter来跟Spinner绑定数据,现阶段一般使用已有的的适配器,如ArrayAdapter,使用方法为、ArrayAdapter<String>adapter=new ArrayAdapter<String>(this,android.R.layout.simple_spinner_dropdown_item,list);
,第二个参数是Spinner未展开菜单时Spinner的默认样式,android.R.layout.simple_spinner_item是系统自带的内置布局,响应事件主要是利用setOnItemSelectedListener,切忌不可弄错,当时项目的过程中就因为粗心选错了导致直接报错;另一种是使用自定义的适配器,下面是来自网上的自写适配器:

/** * 自定义适配器类 *  <a href=http://blog.csdn.net/jiangqq781931404></a> **/public class MyAdapter extends BaseAdapter {    private List<Person> mList;    private Context mContext;    public MyAdapter(Context pContext, List<Person> pList) {        this.mContext = pContext;        this.mList = pList;    }    @Override    public int getCount() {        return mList.size();    }    @Override    public Object getItem(int position) {        return mList.get(position);    }    @Override    public long getItemId(int position) {        return position;    }    /**     * 下面是重要代码     */    @Override    public View getView(int position, View convertView, ViewGroup parent) {        LayoutInflater _LayoutInflater=LayoutInflater.from(mContext);        convertView=_LayoutInflater.inflate(R.layout.item_custom, null);        if(convertView!=null) {            ImageView imageView = (ImageView)convertView.findViewById(R.id.image);            imageView.setImageResource(R.drawable.ic_launcher);            TextView _TextView1=(TextView)convertView.findViewById(R.id.textView1);            TextView _TextView2=(TextView)convertView.findViewById(R.id.textView2);            _TextView1.setText(mList.get(position).getPersonName());            _TextView2.setText(mList.get(position).getPersonAddress());        }        return convertView;    }}

PS:在fragment中使用spinner控件的方法
第一种,主要在于第一个参数使用getActivity() ArrayAdapter<String>adapter=new ArrayAdapter<String>(getActivity(),android.R.layout.simple_spinner_dropdown_item,mac_address);
第二种,其中第二个参数是values/arrays.xml文件,主要是对于下列列表中的元素

<code class=" hljs xml"><!--?xml version="1.0" encoding="utf-8"?--><resources>    <string-array name="options_array">        <item>星期一</item>        <item>星期三</item>        <item>星期四</item>        <item>星期五</item>        <item>星期六</item>        </string-array></resources></code>

下面是调用方法:

ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this, R.array.options_array,android.R.layout.simple_spinner_item);
1 0