標籤:
Spinner控制項也是一種清單類型的控制項,它的繼承關係如下:
java.lang.Object
? android.view.View
? android.view.ViewGroup
? android.widget.AdapterView<Textends android.widget.Adapter>
? android.widget.AbsSpinner
? android.widget.Spinner
android.widget.Spinner繼承了android.view.ViewGroup類。
在Android的UI開發中,Spinner(下拉式清單)總是可以用到的,一個簡單的自訂Spinner製作我們只需要記住這重要的五步,一個Spinner就可以應用而生了。
(1)建立一個android工程,名稱為Spinner。同時建一個Activity,名稱為SpinnerActivity。
(2)修改res/layout/main.xml
[html] view plaincopy
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- >
- <TextView
- android:id = "@+id/TextView_city"
- android:layout_width = "wrap_content"
- android:layout_height = "wrap_content"
- android:text = "所在城市:"
- />
- <!-- 定義一個城市資訊下拉式功能表-->
- <Spinner
- android:id = "@+id/Spinner_city"
- android:layout_width = "wrap_content"
- android:layout_height ="wrap_content" >
- </Spinner >
- </LinearLayout>
(3)SpinnerActivity.java 代碼。
[java] view plaincopy
- package cn.com;
-
- 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.widget.AdapterView;
- import android.widget.ArrayAdapter;
- import android.widget.Spinner;
- import android.widget.TextView;
-
- public class SpinnerActivity 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;
- @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_city);
- 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
- /**
- *
- */
- return false;
- }
- });
- /*下拉式功能表彈出的內容選項焦點改變事件處理*/
- mySpinner.setOnFocusChangeListener(new Spinner.OnFocusChangeListener(){
- public void onFocusChange(View v, boolean hasFocus) {
- // TODO Auto-generated method stub
-
- }
- });
- }
- }
運行結果如所示:
android下拉式功能表spinner的使用方法