使用PopupWindow 实现Spinner 的点击效果

Posted wukj_litai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用PopupWindow 实现Spinner 的点击效果相关的知识,希望对你有一定的参考价值。

在最近我们的项目中有一个小的地方使用到了Spinner,但是android 原生的样式很丑,本来打算在网上找找有没有办法直接修改样式能完成修改,最后没有找到合适的办法,在网上看到有人使用自定义Spinner 的方法进行了解决,我也采用这样的方法解决下。
我实现的效果如下图所示:

在这里我使用的展示popupwindow 的 listview 比较难看,大家可以按照自己的需求进行变化,做成更漂亮的效果,下面是我的实现的思路,附有主要代码,全部的代码在github上,文章的后面会有链接。

在我们的主界面上我们使用一个TextView来显示我们所要显示的内容,下拉的图标是使用TextView的drawableRight 来实现的,其中drawablewomen 还可以设置相应的Padding,主页面的代码比较简单:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.example.administrator.myspinnerpopupwindow.MainActivity"
    tools:showIn="@layout/activity_main">

    <TextView
        android:id="@+id/spinner_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:drawableRight="@drawable/sj"
        android:drawablePadding="5dp"
        android:textSize="20sp"
        android:text="Hello World!" />
</LinearLayout>

主页面的Java代码如下:

package com.example.administrator.myspinnerpopupwindow;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.KeyEvent;
import android.view.MotionEvent;
import android.view.View;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity implements View.OnClickListener, AdapterItemClick 

    private TextView spinner_tv;
    private SpinnerPopupWindow mSpinerPopWindow;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        spinner_tv = (TextView) findViewById(R.id.spinner_tv);
        spinner_tv.setOnClickListener(this);
        spinner_tv.setText("管理人员");
        mSpinerPopWindow = new SpinnerPopupWindow(getApplicationContext(), this);
        mSpinerPopWindow.addData("管理人员");
        mSpinerPopWindow.addData("普通人员");


    


    @Override
    public void onClick(View v) 
        switch (v.getId()) 
            case R.id.spinner_tv:
                showSpinWindow();
                break;
            default:
                break;

        
    

    private void showSpinWindow() 
        Log.e("", "showSpinWindow");
        mSpinerPopWindow.setWidth(spinner_tv.getWidth());
        mSpinerPopWindow.showAsDropDown(spinner_tv);
    

    /**
     * 这个接口实现在PopupWindow中点击子item 会修改spinner_tv 的值
     * @param string_content
     */
    @Override
    public void itemClick(String string_content) 
        spinner_tv.setText(string_content);
        mSpinerPopWindow.dismiss();
    

    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) 

        if (keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) 
            if (mSpinerPopWindow != null && mSpinerPopWindow.isShowing()) 
                mSpinerPopWindow.dismiss();
                return true;
            
        
        return super.onKeyDown(keyCode, event);
    

    @Override
    public boolean onTouchEvent(MotionEvent event) 
        if (mSpinerPopWindow != null && mSpinerPopWindow.isShowing()) 
            mSpinerPopWindow.dismiss();
        
        return super.onTouchEvent(event);
    


AdapterItemClick 接口的代码:

package com.example.administrator.myspinnerpopupwindow;

/**
 * Created by Administrator on 2016/5/6.
 */
public interface AdapterItemClick 
    public void itemClick(String string_content);

我自定义的PopupWindow 的代码:

package com.example.administrator.myspinnerpopupwindow;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.PopupWindow;

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

/**
 * Created by Administrator on 2016/5/6.
 */
public class SpinnerPopupWindow extends PopupWindow implements AdapterView.OnItemClickListener 

    private Context mContext;
    private List<String> list_string;
    private ListView mListView;
    private BaseAdapter mAdapter;
    private AdapterItemClick adapterItemClick;

    public SpinnerPopupWindow(Context context, AdapterItemClick adapterItemClick) 
        mContext = context;
        list_string = new ArrayList<String>();
        this.adapterItemClick = adapterItemClick;
        init();
    

    public void setItemClick(AdapterItemClick adapterItemClick) 

        this.adapterItemClick = adapterItemClick;
    

    private void init() 
        View view = LayoutInflater.from(mContext).inflate(R.layout.spiner_window_layout, null);
        this.setContentView(view);
        setFocusable(false);
        setWidth(ViewGroup.LayoutParams.WRAP_CONTENT);
        setHeight(ViewGroup.LayoutParams.WRAP_CONTENT);
        mListView = (ListView) view.findViewById(R.id.listview);
        mAdapter = new NormalSpinnerAdapter(mContext, list_string);
        mListView.setAdapter(mAdapter);
        mListView.setOnItemClickListener(this);


    


    public void addData(String string_content, int position) 
        list_string.add(position, string_content);
    


    public void addData(String string_content) 
        list_string.add(string_content);
    

    public void addData(List<String> list) 
        if (list == null && list.size() != 0) 
            list_string.addAll(list);
        
    


    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) 
        adapterItemClick.itemClick(list_string.get(position));
    

SpinnerPopupWindow 中使用到的适配器代码:

package com.example.administrator.myspinnerpopupwindow;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

import java.util.List;

/**
 * Created by Administrator on 2016/5/6.
 */
public class NormalSpinnerAdapter extends BaseAdapter 

    private Context mcontext;
    private List<String> list_string;
    private NormalSpinnerAdapter.ViewHolder viewHolder;

    public NormalSpinnerAdapter(Context context, List list_string) 
        mcontext = context;
        this.list_string = list_string;
    

    @Override


    public int getCount() 
        return list_string.size();
    

    @Override
    public Object getItem(int position) 
        return list_string.get(position);
    

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

    @Override
    public View getView(int position, View convertView, ViewGroup parent) 

        if (convertView == null) 
            viewHolder = new ViewHolder();
            convertView = LayoutInflater.from(mcontext).inflate(R.layout.spiner_item_layout, null);
            viewHolder.textView = (TextView) convertView.findViewById(R.id.textView);
            convertView.setTag(viewHolder);
         else 
            viewHolder = (ViewHolder) convertView.getTag();
        
        viewHolder.textView.setText(list_string.get(position));
        return convertView;
    


    class ViewHolder 

        private TextView textView;
    

我们使用到的二个listview 和listview 的item 的布局文件的代码:
spinner_window_layout.xml

<?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:orientation="vertical" 
    android:layout_alignParentRight="true"
    >


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



</LinearLayout>

spinner_item_layout.xml 的布局文件:

<?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"
android:minHeight="40dp">

<TextView
    android:id="@+id/textView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textColor="#ff000000"
    android:textSize="20sp"
    />

</LinearLayout>

就这样我们就完成了这个简单的spinner,代码也很简单,就在代码中不做注释了。
github的地址:https://github.com/wukjlitai/Spinner

以上是关于使用PopupWindow 实现Spinner 的点击效果的主要内容,如果未能解决你的问题,请参考以下文章

Android使用popueWindow自定义Spinner

android中使用PopupWindow实现弹出窗口菜单

自定义控件(仿PopupWindow篇)

自定义控件(仿PopupWindow篇)

PopupWindow的简单使用(结合RecyclerView)

PopupWindow 使用详解