天天看點

android spinner下拉框

下拉框其實自己很少用到,不過昨天因為寫界面時,自己用到了,當時忘記怎麼寫,是以在網上找了一下資料,做了一個自定義的下拉框。這裡,自己把所做的記錄一下,以免自己以後還需要到網上查找。

1.用android提供的spinner下拉框控件。

1.在布局裡添加一個spinner控件

<Spinner android:layout_width="match_parent"

    android:layout_height="wrap_content"

android:id="@+id/spinner2"

android:entries="@array/spingarr"

    />

2.對spinner的資料進行填入。

<?xml version="1.0" encoding="utf-8"?>

<resources>

    <string-array name="spingarr">

     <item>北京</item> 

    <item>上海</item> 

    <item>廣州</item> 

    <item>深圳</item> 

    </string-array>

</resources>

這是在array資源檔案定義的數組,也就是android:entries="@array/spingarr”所引用到的數組。

效果:

android spinner下拉框

這是用資源檔案寫的,不能随意改動,如果用java代碼編寫,則可以随意修改spinner的内容。

布局檔案這樣寫:

<Spinner android:layout_width="match_parent"

    android:layout_height="wrap_content"

    android:id="@+id/spinner"

    />

package com.example.testspanner;

import java.util.ArrayList;

import java.util.List;

import android.app.Activity;

import android.os.Bundle;

import android.widget.ArrayAdapter;

import android.widget.Spinner;

public class MainActivity extends Activity {

private Spinner spinner;

private List<String> data_list;

private ArrayAdapter<String> arr_adapter;

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.spinner);

        spinner = (Spinner) findViewById(R.id.spinner);

        //資料

        data_list = new ArrayList<String>();

        data_list.add("北京");

        data_list.add("上海");

        data_list.add("廣州");

        data_list.add("深圳");

        //擴充卡

        arr_adapter= new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, data_list);

        //設定樣式

        arr_adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

        //加載擴充卡

        spinner.setAdapter(arr_adapter);

    }

}

這個是完全通道android提供的控件,效果我自己覺得太難看了,是以在網上找了一個自定義的控件。

2。通過textView 與popwindow實作自定義的下拉框。

在布局檔案添加一個textView

<TextView
    android:id="@+id/mode"
    android:layout_width="0dp"
    android:layout_height="42dp"
    android:layout_weight="3"
    android:background="@drawable/shape_help_category_tv_bg"
    android:drawableRight="@drawable/icon_down"
    android:padding="10dp"
    android:textColor="@color/content_color"
    android:text="UID"
    android:layout_marginRight="2dp"
    />      

右邊放的是下拉框所需的兩張圖檔,讓後點選時就在textView下彈出popwindow,讓後改變圖檔,當選中popwindow的内容時,textview設定選中的内容,并且改變圖檔。具體的代碼:

private void initSpiner() {
    data_list = new ArrayList<String>();
    data_list.add("UID");
    data_list.add("IP");

    mode.setOnClickListener(clickListener);
    mSpinerPopWindow = new SpinerPopWindow<String>(this, data_list,itemClickListener);
    mSpinerPopWindow.setOnDismissListener(dismissListener);

}      

這個初始化了數組的資料,對textView設定了監聽clickListener,然後建立了一個popwindow,并且設定了點選的監聽itemClickListener和popwindow取消後的監聽dismissListener_edts.

/**
 * 監聽popupwindow取消
 */
private OnDismissListener  dismissListener=new OnDismissListener() {
    @Override
    public void onDismiss() {
        setTextImage(R.drawable.icon_down);
    }
};      

    private AdapterView.OnItemClickListener itemClickListener = new AdapterView.OnItemClickListener() {

        @Override

        public void onItemClick(AdapterView<?> parent, View view, int position,long id) {

            mSpinerPopWindow.dismiss();

            mode.setText(data_list.get(position));

            if (mode.getText().toString().trim().equals("IP")){

               value=true;

                edtUID.setText("");

                lockUnlock(value);

            }else if (mode.getText().toString().trim().equals("UID")){

               value=false;

                edtIP.setText("");

                edtPort.setText("");

                lockUnlock(value);

            }

        }

    };

/**
 * 顯示PopupWindow
 */
private View.OnClickListener clickListener = new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.mode:
                mSpinerPopWindow.setWidth(mode.getWidth());
                mSpinerPopWindow.showAsDropDown(mode);
                setTextImage(R.drawable.icon_up);
                break;
            case R.id.edts:
                mSpinerPopWindow_edts.setWidth(edts.getWidth());
                mSpinerPopWindow_edts.showAsDropDown(edts);
                setTextImage_edts(R.drawable.icon_up);
                break;

        }
    }
};
      
/**
 * 給TextView右邊設定圖檔
 * @param resId
 */
private void setTextImage(int resId) {
    Drawable drawable = getResources().getDrawable(resId);
    drawable.setBounds(0, 0, drawable.getMinimumWidth(),drawable.getMinimumHeight());// 必須設定圖檔大小,否則不顯示
    mode.setCompoundDrawables(null, null, drawable, null);
}
      

這就是主activity的内容,讓後把popwindow的類顯示:

package com.zcloud.p2pviewcam.view;

import java.util.List;

import android.content.Context;
import android.graphics.drawable.ColorDrawable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.PopupWindow;
import android.widget.TextView;

import com.zcloud.p2pviewcam.R;


/**
 * �Զ���PopupWindow  ��Ҫ������ʾListView
 * @author Ansen
 * @param <T>
 * @param <T>
 * @create time 2015-11-3
 */
public class SpinerPopWindow<T> extends PopupWindow {
   private LayoutInflater inflater;
   private ListView mListView;
   private List<T> list;
   private MyAdapter  mAdapter;
   
   public SpinerPopWindow(Context context,List<T> list,OnItemClickListener clickListener) {
      super(context);
      inflater=LayoutInflater.from(context);
      this.list=list;
      init(clickListener);
   }
   
   private void init(OnItemClickListener clickListener){
      View view = inflater.inflate(R.layout.spiner_window_layout, null);
      setContentView(view);     
      setWidth(LayoutParams.WRAP_CONTENT);
      setHeight(LayoutParams.WRAP_CONTENT);
      setFocusable(true);
          ColorDrawable dw = new ColorDrawable(0x00);
      setBackgroundDrawable(dw);
      mListView = (ListView) view.findViewById(R.id.listview);
      mListView.setAdapter(mAdapter=new MyAdapter());
      mListView.setOnItemClickListener(clickListener);
   }
   
   private class MyAdapter extends BaseAdapter{
      @Override
      public int getCount() {
         return list.size();
      }

      @Override
      public Object getItem(int position) {
         return list.get(position);
      }

      @Override
      public long getItemId(int position) {
         return position;
      }

      @Override
      public View getView(int position, View convertView, ViewGroup parent) {
         ViewHolder holder=null;
         if(convertView==null){
            holder=new ViewHolder();
            convertView=inflater.inflate(R.layout.spiner_item_layout, null);
            holder.tvName=(TextView) convertView.findViewById(R.id.tv_name);
            convertView.setTag(holder);
         }else{
            holder=(ViewHolder) convertView.getTag();
         }
         holder.tvName.setText(getItem(position).toString());
         return convertView;
      }
   }
   
   private class ViewHolder{
      private TextView tvName;
   }
}
      

popwindow用到的布局spiner_window_layout,這個很簡單隻是一個listview.

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentRight="true"
    android:orientation="vertical">

    <ListView
        android:id="@+id/listview"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:cacheColorHint="#00000000"
        android:background="@drawable/shape_popupwindow_list_bg"
        android:scrollbars="none" >
    </ListView>
</LinearLayout>      

listview的item布局隻有一個textView,這也很簡單。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center_vertical">

    <TextView
        android:id="@+id/tv_name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="10dp"
        android:text="fdsfdsfdsf"
        android:textColor="@color/content_color"
        android:textSize="15sp"/>

</LinearLayout>      

這裡面有用到一些資源樣式檔案,我就不在寫出來了,如果報錯,可以删除樣式的定義,或者自己定義一些樣式。

這樣,一個自定義的下拉框就完成了。

就這麼簡單。