`
java-admin
  • 浏览: 1381986 次
  • 性别: Icon_minigender_1
  • 来自: 陕西.西安
社区版块
存档分类
最新评论

自定义Spinner五步走

阅读更多

在Android的UI开发中,Spinner(下拉列表)总是可以用到的,一个简单的自定义Spinner制作我们只需要记住这重要的五步,一个Spinner就可以应用而生了。

(1)新建一个Android工程,名字为SpinnerTest1。修改layout下的main.xml,添加一个Textview和一个Spinner,文件内容如下:

Xml代码
  1. <? xml   version = "1.0"   encoding = "utf-8" ?>   
  2. < LinearLayout   
  3.     android:id = "@+id/widget28"   
  4.     android:layout_width = "fill_parent"   
  5.     android:layout_height = "fill_parent"   
  6.     android:orientation = "vertical"   
  7.     xmlns:android = "http://schemas.android.com/apk/res/android"   >   
  8.     < TextView   
  9.         android:id = "@+id/TextView_Show"   
  10.         android:layout_width = "fill_parent"   
  11.         android:layout_height = "wrap_content"   
  12.         android:text = "你选择的是"   
  13.         android:textSize = "25sp" >   
  14.     </ TextView >   
  15.     < Spinner   
  16.         android:id = "@+id/spinner_City"   
  17.         android:layout_width = "fill_parent"   
  18.         android:layout_height = "wrap_content" >   
  19.     </ Spinner > <!-- 定义一个下拉菜单-->   
  20. </ LinearLayout >   
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
	android:id="@+id/widget28"
	android:layout_width="fill_parent"
	android:layout_height="fill_parent"
	android:orientation="vertical"
	xmlns:android="http://schemas.android.com/apk/res/android" >
	<TextView
		android:id="@+id/TextView_Show"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="你选择的是"
		android:textSize="25sp">
	</TextView>
	<Spinner
		android:id="@+id/spinner_City"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content">
	</Spinner><!-- 定义一个下拉菜单-->
</LinearLayout>

 (2)修改你的SpinnerTest1类,在这里我们就要记住五步 来自定义一个Spinner了,完整代码及五步注释如下:

Java代码
  1. package  com.xtlh.spinner;  
  2.   
  3. import  java.util.ArrayList;  
  4. import  java.util.List;  
  5.   
  6. import  android.app.Activity;  
  7. import  android.os.Bundle;  
  8. import  android.view.MotionEvent;  
  9. import  android.view.View;  
  10. import  android.view.View.OnTouchListener;  
  11. import  android.view.animation.Animation;  
  12. import  android.view.animation.AnimationUtils;  
  13. import  android.widget.AdapterView;  
  14. import  android.widget.ArrayAdapter;  
  15. import  android.widget.Spinner;  
  16. import  android.widget.TextView;  
  17.   
  18. public   class  SpinnerTest1  extends  Activity {  
  19.     /** Called when the activity is first created. */   
  20.     private  List<String> list =  new  ArrayList<String>();  
  21.     private  TextView myTextView;  
  22.     private  Spinner mySpinner;  
  23.     private  ArrayAdapter<String> adapter;  
  24.     private  Animation myAnimation;  
  25.     @Override   
  26.     public   void  onCreate(Bundle savedInstanceState) {  
  27.         super .onCreate(savedInstanceState);  
  28.         setContentView(R.layout.main);  
  29.         //第一步:添加一个下拉列表项的list,这里添加的项就是下拉列表的菜单项   
  30.         list.add("北京" );  
  31.         list.add("上海" );  
  32.         list.add("深圳" );  
  33.         list.add("南京" );  
  34.         list.add("重庆" );  
  35.         myTextView = (TextView)findViewById(R.id.TextView_Show);  
  36.         mySpinner = (Spinner)findViewById(R.id.spinner_City);  
  37.         //第二步:为下拉列表定义一个适配器,这里就用到里前面定义的list。   
  38.         adapter = new  ArrayAdapter<String>( this ,android.R.layout.simple_spinner_item, list);  
  39.         //第三步:为适配器设置下拉列表下拉时的菜单样式。   
  40.         adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);  
  41.         //第四步:将适配器添加到下拉列表上   
  42.         mySpinner.setAdapter(adapter);  
  43.         //第五步:为下拉列表设置各种事件的响应,这个事响应菜单被选中   
  44.         mySpinner.setOnItemSelectedListener(new  Spinner.OnItemSelectedListener(){  
  45.             public   void  onItemSelected(AdapterView<?> arg0, View arg1,  int  arg2,  long  arg3) {  
  46.                 // TODO Auto-generated method stub   
  47.                 /* 将所选mySpinner 的值带入myTextView 中*/   
  48.                 myTextView.setText("您选择的是:" + adapter.getItem(arg2));  
  49.                 /* 将mySpinner 显示*/   
  50.                 arg0.setVisibility(View.VISIBLE);  
  51.             }  
  52.             public   void  onNothingSelected(AdapterView<?> arg0) {  
  53.                 // TODO Auto-generated method stub   
  54.                 myTextView.setText("NONE" );  
  55.                 arg0.setVisibility(View.VISIBLE);  
  56.             }  
  57.         });  
  58.         /*下拉菜单弹出的内容选项触屏事件处理*/   
  59.         mySpinner.setOnTouchListener(new  Spinner.OnTouchListener(){  
  60.             public   boolean  onTouch(View v, MotionEvent event) {  
  61.                 // TODO Auto-generated method stub   
  62.                 /* 将mySpinner 隐藏,不隐藏也可以,看自己爱好*/   
  63.                 v.setVisibility(View.INVISIBLE);  
  64.                 return   false ;  
  65.             }  
  66.         });  
  67.         /*下拉菜单弹出的内容选项焦点改变事件处理*/   
  68.         mySpinner.setOnFocusChangeListener(new  Spinner.OnFocusChangeListener(){  
  69.         public   void  onFocusChange(View v,  boolean  hasFocus) {  
  70.         // TODO Auto-generated method stub   
  71.             v.setVisibility(View.VISIBLE);  
  72.         }  
  73.         });  
  74.     }  
  75. }  
package com.xtlh.spinner;

import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.TextView;

public class SpinnerTest1 extends Activity {
    /** Called when the activity is first created. */
	private List<String> list = new ArrayList<String>();
	private TextView myTextView;
	private Spinner mySpinner;
	private ArrayAdapter<String> adapter;
	private Animation myAnimation;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        //第一步:添加一个下拉列表项的list,这里添加的项就是下拉列表的菜单项
        list.add("北京");
        list.add("上海");
        list.add("深圳");
        list.add("南京");
        list.add("重庆");
        myTextView = (TextView)findViewById(R.id.TextView_Show);
        mySpinner = (Spinner)findViewById(R.id.spinner_City);
        //第二步:为下拉列表定义一个适配器,这里就用到里前面定义的list。
        adapter = new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item, list);
        //第三步:为适配器设置下拉列表下拉时的菜单样式。
        adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
        //第四步:将适配器添加到下拉列表上
        mySpinner.setAdapter(adapter);
        //第五步:为下拉列表设置各种事件的响应,这个事响应菜单被选中
        mySpinner.setOnItemSelectedListener(new Spinner.OnItemSelectedListener(){
	        public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
		        // TODO Auto-generated method stub
		        /* 将所选mySpinner 的值带入myTextView 中*/
		        myTextView.setText("您选择的是:"+ adapter.getItem(arg2));
		        /* 将mySpinner 显示*/
		        arg0.setVisibility(View.VISIBLE);
	        }
	        public void onNothingSelected(AdapterView<?> arg0) {
		        // TODO Auto-generated method stub
		        myTextView.setText("NONE");
		        arg0.setVisibility(View.VISIBLE);
	        }
        });
        /*下拉菜单弹出的内容选项触屏事件处理*/
        mySpinner.setOnTouchListener(new Spinner.OnTouchListener(){
	        public boolean onTouch(View v, MotionEvent event) {
		        // TODO Auto-generated method stub
		        /* 将mySpinner 隐藏,不隐藏也可以,看自己爱好*/
		        v.setVisibility(View.INVISIBLE);
		        return false;
	        }
        });
        /*下拉菜单弹出的内容选项焦点改变事件处理*/
        mySpinner.setOnFocusChangeListener(new Spinner.OnFocusChangeListener(){
        public void onFocusChange(View v, boolean hasFocus) {
        // TODO Auto-generated method stub
        	v.setVisibility(View.VISIBLE);
        }
        });
    }
}

 

 记住这五步后,一个Spinner就Ok了,其中在为Spinner的适配器设置下拉时的菜单样式时,我们可以自定义自己的样式,如果嫌麻烦,就直接用android.R.layout的,就如下面这样。
        adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
效果图如下:


http://sinye.iteye.com/blog/627023

 

 

分享到:
评论
1 楼 woaicuiyu1212 2012-06-30  
非常有帮助,不过怎么去设置下拉菜单的样式呢?

相关推荐

    Android自定义Spinner样式

    默认情况下,Spinner的样式可能无法满足所有设计需求,因此开发者常常需要对其进行自定义,以实现更个性化的视觉效果。本文将详细介绍如何自定义Android Spinner的样式,包括选择框背景、选择框文字属性以及弹出框...

    简单的自定义Spinner

    ### 知识点详解:简单的自定义Spinner #### 一、引言 在Android开发过程中,经常需要使用到`Spinner`这一控件来提供用户选择的功能。然而,默认的`Spinner`样式可能无法满足设计师或者产品经理对UI的要求。因此,...

    Android 自定义spinner控件下拉框实现

    本篇文章将深入探讨如何通过自定义控件来实现一个具有更多灵活性的Spinner替代方案。 首先,我们创建一个新的布局文件,继承自LinearLayout,作为自定义Spinner的基础。这样做可以让我们更好地控制布局的结构和样式...

    自定义spinner

    自定义Spinner可以帮助我们根据应用程序的需求调整其外观和行为,以提供更好的用户体验。在这个"自定义spinner的小列子"中,虽然存在一些缺陷,但我们可以从中学到一些关键的知识点。 首先,我们要了解Spinner的...

    自定义Spinner

    "自定义Spinner"是指开发者根据实际需求,对系统默认的Spinner进行功能扩展或者样式调整,以达到更好的用户体验或者特定的设计效果。本篇文章将深入探讨如何在Android中自定义Spinner,并通过实例项目`...

    自定义Spinner(PopupWindow实现的弹出下拉框)

    然而,系统默认的Spinner样式可能不能满足所有设计需求,因此开发者常常需要自定义Spinner来实现更丰富的交互效果。本节我们将深入探讨如何使用PopupWindow实现一个自定义的Spinner,以获得类似网站下拉窗口的效果。...

    Android城市级联下拉框(自定义Spinner)

    这种效果通常通过自定义Spinner来完成。Spinner是Android中的一个下拉选择控件,它提供了用户友好的交互方式,允许用户在一组预设选项中进行选择。 **1. Spinner的基本使用** Spinner的使用主要包括两步:创建...

    android自定义Spinner

    然而,标题"android自定义Spinner"表明我们将探讨如何超越默认的显示方式,即避免使用Dialog形式,而是实现一个下拉式的Spinner显示。 1. **Spinner基础知识**: - Spinner是Android SDK中的一个视图组件,属于...

    自定义spinner样式

    自定义Spinner的关键在于创建一个自定义的布局文件,该布局文件将作为每个Spinner条目的模板。通常,这会包含一个TextView,但也可以包括其他视图元素,如ImageView或CheckBox。例如,在`res/layout/custom_spinner...

    自定义Spinner实现初始项不参与列表显示(Spinner添加“请选择”)

    本文将详细介绍如何自定义Spinner以实现这种功能。 ### 1. 创建“请选择”项 首先,我们需要在布局文件中为Spinner定义一个特殊的TextView,用于显示“请选择”这一初始选项。这可以通过在Spinner的布局中添加一个...

    Android自定义Spinner

    然而,当我们需要自定义Spinner的下拉样式时,原生的Spinner就显得力不从心了。这时,我们可以利用PopupWindow来替代Spinner的下拉菜单。PopupWindow是一个可以浮现在屏幕任意位置的窗口,它的灵活性非常高,可以...

    Android自定义spinner下拉框实现的实现

    本篇文章将详细讲解如何自定义一个Android Spinner的下拉框实现,以提供更加个性化的用户体验。 首先,我们需要了解Spinner的基本用法。Spinner通常通过Adapter来绑定数据源,常见的有ArrayAdapter、...

    android自定义spinner下拉框实现(封装更通用)

    博文参考:http://blog.csdn.net/geniuseoe2012/article/details/8723702 android仿web风格的spinner下拉框实现demo,实现更通用

    自定义Spinner--利用TextView以及Dialog组合

    本教程将深入探讨如何实现一个自定义的Spinner,该Spinner是通过结合TextView和Dialog来创建的,以提供更灵活和个性化的用户体验。 ### 自定义Spinner的基本原理 1. **TextView**:TextView是Android中的基本组件...

    MaterialSpinner 自定义Spinner

    然而,系统默认的Spinner样式和交互可能无法满足所有设计需求,这时我们就需要对其进行自定义。"MaterialSpinner"项目就是针对这种情况提供的一种解决方案,它基于Android的Spinner进行了增强,提供了更美观、更符合...

    Android自定义spinner下拉框

    Android自定义spinner下拉框实现的实现 http://blog.csdn.net/jdsjlzx/article/details/41316417 请支持原创:http://blog.csdn.net/geniuseoe2012/article/details/8723702

    android自定义spinner

    自定义Spinner可以帮助我们实现更个性化的界面设计,以适应不同的设备和用户需求。本篇文章将深入探讨如何在Android中自定义Spinner,并分享一个适配平板的示例。 首先,我们需要了解Spinner的基本使用。在Android...

    android自定义Spinner下拉菜单(下拉列表框)样式

    android自定义Spinner下拉菜单(下拉列表框)样式

    android 自定义Spinner

    自定义Spinner时,需要创建一个自定义的Adapter,以便将数据转化为Spinner可展示的视图。这个Adapter可以继承自BaseAdapter或ArrayAdapter,并重写其中的方法,如getView(),以达到自定义显示效果。 6. **点击事件...

Global site tag (gtag.js) - Google Analytics