Android使用Spinner控件实现下拉列表的案例

 更新时间:2019年03月28日 16:53:29   作者:徐刘根  
今天小编就为大家分享一篇关于Android使用Spinner控件实现下拉列表的案例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

(1)两种方法提冲Spinner中的数据源:通过list集合,或者是通过xml文件进行配置

(2)布局代码如下:

<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=".MainActivity" >
  <TextView
    android:id="@+id/textView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentLeft="true"
    android:layout_alignParentTop="true"
    android:layout_marginTop="46dp"
    android:text="所属城市"
    android:textSize="22sp" />
  <Spinner
    android:id="@+id/spinner1"
    android:layout_width="200sp"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_marginTop="44dp"
    android:layout_toRightOf="@+id/textView1" />
  <TextView
    android:id="@+id/textView2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignRight="@+id/textView1"
    android:layout_centerVertical="true"
    android:text="所属星球" />
  <Spinner
    android:id="@+id/spinner2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignLeft="@+id/spinner1"
    android:layout_alignTop="@+id/textView2"
    android:layout_marginLeft="21dp" />
</RelativeLayout>

(3)

package com.example.spinners;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.Toast;
/**
 * 通过继承OnItemSelectedListener接口来实现选择时的事件
 * @author xuliugen
 *
 */
public class MainActivity extends Activity implements OnItemSelectedListener {
 private Spinner spinner1;
 private Spinner spinner2;
 // private SpinnerAdapter spinnerAdapter;
 private ArrayAdapter<String> adapter;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 spinner1 = (Spinner) this.findViewById(R.id.spinner1);
 spinner2 = (Spinner) this.findViewById(R.id.spinner2);
 // 第一种手工输入的list
 adapter = new ArrayAdapter<String>(MainActivity.this,
  android.R.layout.simple_spinner_item, getDataSource());
 spinner1.setAdapter(adapter);
 //注册监听器
 spinner1.setOnItemSelectedListener(this);
 // 第二种:通过加载xml文件配置的数据源
 ArrayAdapter adapter2 = ArrayAdapter.createFromResource(this,
  R.array.planets_array, android.R.layout.simple_spinner_item);
 adapter2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
 spinner2.setAdapter(adapter2);
 }
 /*
 * 通过第一种方法:手工输入的list
 */
 public List<String> getDataSource() {
 List<String> list = new ArrayList<String>();
 list.add("beijing");
 list.add("beida");
 list.add("shahai");
 list.add("shangjing");
 list.add("shanglian");
 list.add("chengdu");
 return list;
 }
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
 getMenuInflater().inflate(R.menu.main, menu);
 return true;
 }
 @Override
 public void onItemSelected(AdapterView<?> parent, View view, int position,
  long id) {
 String itemString = spinner1.getItemAtPosition(position).toString();
 Toast.makeText(this, "你选中的是" + itemString, 1).show();
 }
 @Override
 public void onNothingSelected(AdapterView<?> parent) {
 }
}

(4)资源文件中的配置如下:

<?xml version="1.0" encoding="utf-8"?>
<resources>
  <string name="app_name">Spinners</string>
  <string name="action_settings">Settings</string>
  <string name="hello_world">Hello world!</string>
  <string-array name="planets_array">
    <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>
</resources>

(5)运行结果如下所示:

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • Android Jetpack组件支持库DataBinding与ViewModel与LiveData及Room详解

    Android Jetpack组件支持库DataBinding与ViewModel与LiveData及Room

    Jetpack是一个由多个技术库组成的套件,可帮助开发者遵循最佳做法,减少样板代码并编写可在各种Android版本和设备中一致运行的代码,让开发者精力集中编写重要的代码
    2022-09-09
  • 使用ViewPager实现高仿launcher左右拖动效果

    使用ViewPager实现高仿launcher左右拖动效果

    今天用ViewPager这个类实现了同样的左右拖动效果,这样代码更少,但是效果是一样的,ViewPager是实现左右两个屏幕平滑地切换的一个类,它是Google提供的,有需要的朋友可以了解下
    2013-01-01
  • Android开发之高德地图实现定位

    Android开发之高德地图实现定位

    本篇文章主要介绍了Android中高德地图实现定位的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • Android LinearLayout实现自动换行

    Android LinearLayout实现自动换行

    这篇文章主要为大家详细介绍了Android LinearLayout实现自动换行,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • Android仿String的对象驻留示例分析

    Android仿String的对象驻留示例分析

    这篇文章主要介绍了Android仿String的对象驻留,较为详细的分析说明了对象驻留的概念及Android实现仿String对象驻留的相关技巧,需要的朋友可以参考下
    2015-12-12
  • Android利用绘制缓冲实现代码雨效果

    Android利用绘制缓冲实现代码雨效果

    看过很多代码雨的前端实现,却很少看到过Android代码雨效果的实现,当然 open gl es的实现是有的,一个主要的原因是,在Android Canvas绘制时,很少有人考虑使用绘制缓冲,所以本文将给大家介绍Android如何利用绘制缓冲实现代码雨效果,需要的朋友可以参考下
    2024-03-03
  • Kotlin类对象class初始化与使用

    Kotlin类对象class初始化与使用

    Kotlin 是一种追求简洁的语言,在类上也下了不少功夫,放弃了很多c++ 中类非常复杂的概念,其实对于类可以这样来理解,为了复用的方便性和完整性,我们把变量和函数组合在一起,形成了类的概念
    2022-12-12
  • Android Activity生命周期详解

    Android Activity生命周期详解

    本篇文章主要介绍Android Activity的生命周期,这里整理了关于Activity的生命周期资料并附测试代码示例,有兴趣的小伙伴可以参考下
    2016-08-08
  • Android实现仿通讯录侧边栏滑动SiderBar效果代码

    Android实现仿通讯录侧边栏滑动SiderBar效果代码

    这篇文章主要介绍了Android实现仿通讯录侧边栏滑动SiderBar效果代码,实例分析了通讯录侧边栏滑动效果的实现技巧,并附带完整实例代码供读者下载参考,需要的朋友可以参考下
    2015-10-10
  • Flutter图片缓存管理ImageCache原理分析

    Flutter图片缓存管理ImageCache原理分析

    这篇文章主要为大家介绍了Flutter图片缓存管理ImageCache原理分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12

最新评论