专栏首页分享达人秀下拉框Spinner就这么简单

下拉框Spinner就这么简单

上一期学习了GridView的使用,你已经掌握了吗?本期一起来学习Spinner的使用。

一、认识Spinner

Spinner其实就是一个列表选择框。不过Android的列表选择框并不需要显示下拉列表,而是相当于弹出一个菜单供用户选择。

Spinner 与 Gallery 都继承了AbsSpinner,AbsSpinner 继承了AdapterView,因此它也表现出AdapterView的特征:只要为AdapterView提供Adapter即可。

Spinner支持的常用XML属性及相关方法如下表所示。

XML属性

相关方法

说明

android:dropDownHorizontalOffest

setDropDownHorizontalOffest(int)

设置列表选择框的水平偏移距离

android:dropDownVerticalOffest

setDropDownVerticalOffest(int)

设置列表选择框的垂直偏移距离

android:dropDownSelector

setDropDownSelector(int)

设置列表选择框选中时的背景

android:dropDownWidth

setDropDownWidth(int)

设置列表选择框的宽度

android:popupBackground

setPopupBackground(String)

设置列表选择框的背景色

android:prompt

setPrompt(String)

设置列表选择框的提示消息

android:spinnerMode

设置列表框的模式,有2个可选值: dialog:对话框风格的窗口 dropdown:下拉菜单风格的窗口

如果开发者使用Spinner时己经可以确定列表选择框里的列表项,则完全不需要编写代码,只要为Spinner指定android:entries属性即可让Spinner正常工作;如果程序需要在运行时动态 地决定Spinner的列表项,或者程序需要对Spinner的列表项进行定制,则可使用Adapter为 Spinner提供列表项。

二、Spinner示例

接下来通过一个简单的示例程序来学习Spinner的使用方法。

继续使用WidgetSample工程的listviewsample模块,在app/main/res/layout/目录下创建spinner_layout.xml文件,在其中填充如下代码片段:

<?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="vertical"
              android:padding="5dp" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="选择专业方向"
        android:textColor="#44BDED"
        android:textSize="18sp" />

    <Spinner
        android:id="@+id/spin_one"
        android:layout_width="100dp"
        android:layout_height="64dp"
        android:entries="@array/professionals"
        android:spinnerMode="dialog" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp"
        android:text="选择教科书"
        android:textColor="#F5684A"
        android:textSize="18sp" />

    <Spinner
        android:id="@+id/spin_two"
        android:layout_width="wrap_content"
        android:layout_height="64dp" />
</LinearLayout>

在res/values/目录下新建arrays.xml文件,定义professionals数组资源,如下:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string-array name="professionals">
        <item>Android</item>
        <item>Java</item>
        <item>Python</item>
        <item>PHP</item>
        <item>.Net</item>
        <item>C++</item>
        <item>C</item>
    </string-array>
</resources>

接下来为Spinner提供Adapter。新建SpinnerActivity.java文件,加载上面新建的布局文件,具体代码如下:

package com.jinyu.cqkxzsxy.android.listviewsample;


import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.Toast;


public class SpinnerActivity extends AppCompatActivity
        implements AdapterView.OnItemSelectedListener {
    private Spinner mProSpinner = null;
    private Spinner mBookSpinner = null;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.spinner_layout);


        // 获取界面布局文件中的Spinner组件
        mProSpinner = (Spinner) findViewById(R.id.spin_one);
        mBookSpinner = (Spinner) findViewById(R.id.spin_two);


        String[] arr = { "初识Android开发", "Android初识开发", "Android中级开发",
                "Android高级开发", "Android开发进阶"};

        // 创建ArrayAdapter对象
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
                android.R.layout.simple_list_item_1, arr);

        // 为Spinner设置Adapter
        mBookSpinner.setAdapter(adapter);


        // 为Spinner设置选中事件监听器
        mProSpinner.setOnItemSelectedListener(this);
        mBookSpinner.setOnItemSelectedListener(this);
    }


    @Override
    public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
        String content = parent.getItemAtPosition(position).toString();
        switch (parent.getId()){
            case R.id.spin_one:
                Toast.makeText(SpinnerActivity.this, "选择的专业是:" + content,
                        Toast.LENGTH_SHORT).show();
                break;
            case R.id.spin_two:
                Toast.makeText(SpinnerActivity.this, "选择的教材是:" + content,
                        Toast.LENGTH_SHORT).show();
                break;
            default:
                break;
        }
    }


    @Override
    public void onNothingSelected(AdapterView<?> adapterView) {
    }
}

上面的程序比较简单,主要为Spinner 设置了选中设置监听器。

修改程序启动的Activity,运行程序,可以看到下图所示界面效果。

点击第一个Spinner ,弹出选择对话框,如下图所示。选择其中一项回到主界面,发现Spinner 的值会改变为所选择的内容。

同理点击第二个Spinner ,打开下拉列表选项框,如下图所示。

Gallery与Spinner组件有共同的父类:AbsSpinner,表明Gallery和Spinner都是一个列表选择框。它们之间的区别在于,Spinner显示的是一个垂直的列表选择框,而Gallery显示的是一个水平的列表选择框。 Gallery与Spinner还有一个区别:Spinner的作用是供用户选择,而Gallery则允许用户通过拖动来查看上一个、下一个列表项。

Gallery本身的用法非常简单——基本上与Spinner的用法相似,只要为它提供一个内容 Adapter即可,该Adapter的getView()方法所返回的View将作为Gallery列表的列表项。如果程序需要监控到Gallery选择项的改变,通过为Gallery添加OnltemSelectedListener监听器即可实现。

Android已经不再推荐使用Gallery组件,而是推荐使用其他水平滚动组件,如HorizontalScrollView和ViewPager来代替Gallery组件,所以此处不做过多讲解。

本文分享自微信公众号 - 分享达人秀(ShareExpert),作者:鑫鱻

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-08-26

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ViewPager轻松完成TabHost效果

    上一期学习了ViewPager的简单使用,本期一起来学习ViewPager的更多用法。 ? 相信很多同学都使用过今日头条APP吧,一打开主界面就...

    分享达人秀
  • 最简单最常用的LinearLayout线性布局

    良好的布局设计对于UI界面至关重要,在前面也简单介绍过,目前Android中的布局主要有6种,创建的布局文件默认为RelativeLayout相对布局,...

    分享达人秀
  • Activity数据回传

    上一节学习了将简单的数据从MainActivity传递到SecondActivity,本节一起来学习数据如何从SecondActivity回传到Main...

    分享达人秀
  • 仿电商商品分类的思路实现

    Anonymous_95975_565
  • PL/SQL变长数组

      PL/SQL变长数组时PL/SQL集合数据类型中的一种,其使用方法与PL/SQL嵌套表大同小异,唯一的区别则是变长数组的元素的最大个数是有限 制的。也即是说...

    Leshami
  • web前端常见面试题解析之函数节流与防抖(一)

    我们可以将这个定义进行一下拆分: 1、所谓函数节流指的就是一个函数。 2、该函数的执行需要一个周期进行控制。 3、周期内调用该函数不执行,否则会执行。

    用户1272076
  • Mysql常用sql语句(23)- update 修改数据

    https://www.cnblogs.com/poloyy/category/1683347.html

    小菠萝测试笔记
  • 一名程序员妹纸如何四面拿下美团offer?

    美团,我是在拉勾网上投的简历,之前也投过一次,简历都没通过删选,后来让学姐帮我改了一下简历,重新投另一个部门,获得了面试机会。

    Java知音
  • input checkbox 复选框大小修改

    其实就是zoom属性,这个是放大的意思,可以设置为180%,这样就会比之前大很多。

    一个会写诗的程序员
  • Hadoop应用案例分析:P2P借款人信用风险实时监控模型设计

    一提到hadoop相信熟悉IT领域或者经常关注互联网新闻的朋友都应该很熟悉了,当然,这种熟悉可能也只是听着名字耳熟,但并不知道它具体是什么东西,或者用来做什么。...

    IT小白龙

扫码关注云+社区

领取腾讯云代金券