popupWindow自定义(2)

popupWindow自定义(1)
popupWindow自定义(2)
首先看看效果图:


接着上篇文章的,上次讲述了自定义的密码框发现在时间使用过程中,当点击物理按键返回,密码框不消失,而是当前的Activity退出了,这次优化了这个bug一些默认的配置封装起来了,且在使用的时候更加方便。不多说,直接贴代码:

自定义密码框:


import android.content.Context;
import android.graphics.drawable.ColorDrawable;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.PopupWindow;
import android.widget.TextView;

import com.skypine.skypine.R;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;

public class PasswordPopupWindow extends PopupWindow {
    private Context mContext;

    private View                           mMenuView;
    private String                         mStringPassword; //输入的密码
    private TextView[]                     mTextViewPsw; // 用数组保存6个TextView
    private GridView                       mGridView; //支付键盘布局
    private ArrayList<Map<String, String>> valueList;
    private ImageView                      mImageViewCancel;
    private TextView                       mTextViewForgetPsw;
    private int currentIndex = -1;// 用于记录当前输入密码格位置
    private TextView mTextViewTitle;
    private TextView mTextViewDel;
    private TextView cancelButton;
    private TextView okButton;
    private OnCancelListener cancelListener; //取消

    public PasswordPopupWindow(Context context) {
        super(context);
        mContext = context;
        LayoutInflater inflater = (LayoutInflater) context
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        mMenuView = inflater.inflate(R.layout.password_dialog, null);

        valueList = new ArrayList<>();
        mTextViewPsw = new TextView[6];
        mImageViewCancel = (ImageView) mMenuView.findViewById(R.id.iv_pay_back);
        mTextViewPsw[0] = (TextView) mMenuView.findViewById(R.id.tv_pass1);
        mTextViewPsw[1] = (TextView) mMenuView.findViewById(R.id.tv_pass2);
        mTextViewPsw[2] = (TextView) mMenuView.findViewById(R.id.tv_pass3);
        mTextViewPsw[3] = (TextView) mMenuView.findViewById(R.id.tv_pass4);
        mTextViewPsw[4] = (TextView) mMenuView.findViewById(R.id.tv_pass5);
        mTextViewPsw[5] = (TextView) mMenuView.findViewById(R.id.tv_pass6);
        mGridView = (GridView) mMenuView.findViewById(R.id.gv_keybord);
        mTextViewTitle = (TextView) mMenuView.findViewById(R.id.tv_pay_title);
        mTextViewForgetPsw = (TextView) mMenuView.findViewById(R.id.tv_pay_forgetPwd);
        /**/
        cancelButton = (TextView) mMenuView.findViewById(R.id.cancelButton);
        okButton = (TextView) mMenuView.findViewById(R.id.okButton);

        setView();
        //取消按钮
        cancelButton.setOnClickListener(new OnClickListener() {

            public void onClick(View v) {
                //取消
                cancelListener.OnCancel();
                //销毁弹出框
                dismiss();
            }
        });
    
        //设置SelectPicPopupWindow的View
        this.setContentView(mMenuView);
        //设置SelectPicPopupWindow弹出窗体的宽
        this.setWidth(LayoutParams.FILL_PARENT);
        //设置SelectPicPopupWindow弹出窗体的高
        this.setHeight(LayoutParams.WRAP_CONTENT);
        //设置SelectPicPopupWindow弹出窗体可点击
        this.setFocusable(true);
        //设置SelectPicPopupWindow弹出窗体动画效果
        this.setAnimationStyle(R.style.mypopwindow_anim_style);
        //实例化一个ColorDrawable颜色为半透明
        ColorDrawable dw = new ColorDrawable(0xb0000000);
        //设置SelectPicPopupWindow弹出窗体的背景
        this.setBackgroundDrawable(dw);
        //mMenuView添加OnTouchListener监听判断获取触屏位置如果在选择框外面则销毁弹出框
        mMenuView.setOnTouchListener(new OnTouchListener() {

            public boolean onTouch(View v, MotionEvent event) {

                int height = mMenuView.findViewById(R.id.pop_layout).getTop();
                int y = (int) event.getY();
                if (event.getAction() == MotionEvent.ACTION_UP) {
                    if (y < height) {
                        dismiss();
                    }
                }
                return true;
            }
        });

    }

    /*********************
     * 取消
     ******************/
    public interface OnCancelListener {
        public void OnCancel();
    }

    public void setCancelListener(OnCancelListener cancelListener) {
        this.cancelListener = cancelListener;
    }


    // 初始化按钮上应该显示的数字

    private void setView() {
        for (int i = 1; i < 13; i++) {
            Map<String, String> map = new HashMap<>();
            if (i < 10) {
                map.put("name", String.valueOf(i));
            } else if (i == 10) {//没有
                map.put("name", "");
            } else if (i == 11) {//
                map.put("name", String.valueOf(0));
            } else if (i == 12) {
                map.put("name", "");
            } else if (i == 13) {
                map.put("name", " ");
            } else if (i == 14) {
                map.put("name", "");
            }
            valueList.add(map);
        }
        mGridView.setAdapter(adapter);
    }

    public interface OnPasswordInputFinish {
        public void inputFinish();
    }

    /**
     * 设置监听方法,在第6位输入完后触发
     */
    public void setOnFinishInput(final OnPasswordInputFinish pass) {
        mTextViewPsw[5].addTextChangedListener(new TextWatcher() {
            @Override
            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
            }

            @Override
            public void onTextChanged(CharSequence s, int start, int before, int count) {
            }

            @Override
            public void afterTextChanged(Editable s) {
                if (s.toString().length() == 1) {
                    mStringPassword = ""; //每次触发都要将mStringPassword置空再重新获取,避免由于输入删除再输入造成混乱
                    for (int i = 0; i < 6; i++) {
                        mStringPassword += mTextViewPsw[i].getText().toString().trim();
                    }
                    pass.inputFinish();//接口中要实现的方法,完成密码输入完成后的响应逻辑
                }
            }
        });


    }


    /**
     * 清除所有密码
     */

    public void clearAll() {
        //        currentIndex= -1;
        //        mTextViewPsw[0].setBackgroundResource(R.drawable.bg_circle_num_pwd);
        //        mTextViewPsw[1].setBackgroundResource(R.drawable.bg_circle_num_pwd);
        //        mTextViewPsw[2] .setBackgroundResource(R.drawable.bg_circle_num_pwd);
        //        mTextViewPsw[3]. setBackgroundResource(R.drawable.bg_circle_num_pwd);
        //        mTextViewPsw[4]. setBackgroundResource(R.drawable.bg_circle_num_pwd);
        //        mTextViewPsw[5].setBackgroundResource(R.drawable.bg_circle_num_pwd);
        //        mTextViewPsw[0].setText("");
        //        mTextViewPsw[1].setText("");
        //        mTextViewPsw[2] .setText("");
        //        mTextViewPsw[3]. setText("");
        //        mTextViewPsw[4]. setText("");
        //        mTextViewPsw[5].setText("");
        currentIndex = 5;

        while (true)
            if (currentIndex - 1 >= -1) { // 判断是否删除完毕
                TextView temp = mTextViewPsw[currentIndex--];
                temp.setText("");
                temp.setBackgroundResource(R.drawable.bg_circle_num_pwd);
            } else {
                break;
            }


    }

    /**
     * 获取输入的密码
     */
    public String getPassword() {
        return mStringPassword;
    }

    /**
     * 返回取消支付的ImageView
     */
    public ImageView getCancel() {
        return mImageViewCancel;
    }
    //    /**
    //     * 返回取消
    //     */
    //    public TextView getmTextViewCancel() {
    //        return mTextViewCancel;
    //    }


    /**
     * 返回忘记密码的TextView
     */
    public TextView getForgetPsw() {
        return mTextViewForgetPsw;
    }

    /**
     * 返回标题的TextView
     */
    public TextView getTitle() {
        return mTextViewTitle;
    }

    /**
     * GridView的适配器
     */
    BaseAdapter adapter = new BaseAdapter() {
        @Override
        public int getCount() {
            return valueList.size();
        }

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

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

        @Override
        public View getView(final int position, View convertView, ViewGroup parent) {
            ViewHolder holder;
            if (convertView == null) {
                convertView = View.inflate(mContext, R.layout.item_pay_gride, null);
                holder = new ViewHolder();
                holder.btnKey = (Button) convertView.findViewById(R.id.btn_keys);
                convertView.setTag(holder);
            } else {
                holder = (ViewHolder) convertView.getTag();
            }
            holder.btnKey.setText(valueList.get(position).get("name"));
            if (position == 12) {
                holder.btnKey.setText("取消");
            }
            if (position == 14) {
                mTextViewDel = holder.btnKey;
                holder.btnKey.setText("删除");
            }
            if (position == 9 || position == 11 || position == 13) {
                holder.btnKey.setBackground(null);
                holder.btnKey.setText("");
            }
            okButton.setOnClickListener(new OnClickListener() {
                @Override
                public void onClick(View v) {
                    if (currentIndex - 1 >= -1) { // 判断是否删除完毕
                        TextView temp = mTextViewPsw[currentIndex--];
                        temp.setText("");
                        temp.setBackgroundResource(R.drawable.bg_circle_num_pwd);
                    }
                }
            });

            holder.btnKey.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    if (position < 11 && currentIndex != 9 && position != 9) { //点击0-9按钮
                        if (currentIndex >= -1 && currentIndex < 5) { //判断输入位置
                            TextView temp = mTextViewPsw[++currentIndex];
                            temp.setText(valueList.get(position).get("name"));
                            temp.setBackgroundResource(R.drawable.bg_circle_num_pwd_visiable);
                        }
                    } else {
                        if (position == 14) { //点击退格键
                            if (currentIndex - 1 >= -1) { // 判断是否删除完毕
                                TextView temp = mTextViewPsw[currentIndex--];
                                temp.setText("");
                                temp.setBackgroundResource(R.drawable.bg_circle_num_pwd);
                            }
                        }
                        if (position == 12) {
                            //退出
                            cancelListener.OnCancel();
                        }
                    }
                }
            });
            return convertView;
        }
    };

    static class ViewHolder {
        public Button btnKey;
    }

}

xml文件:

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

    <LinearLayout
        android:id="@+id/pop_layout"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:gravity="center_horizontal"
        android:orientation="vertical">

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@color/colorPrimary"
            android:orientation="vertical">

            <LinearLayout
                android:id="@+id/ll_main_password"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical">

                <RelativeLayout
                    android:layout_width="match_parent"
                    android:layout_height="50dp">

                    <ImageView
                        android:id="@+id/iv_pay_back"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_centerVertical="true"
                        android:layout_marginLeft="10dp"/>

                    <TextView
                        android:id="@+id/tv_pay_title"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_centerHorizontal="true"
                        android:layout_marginLeft="15dp"
                        android:layout_marginTop="15dp"
                        android:text="@string/pin_id"
                        android:textColor="@color/white"
                        android:textSize="18dp"/>
                </RelativeLayout>

                <!-- 6位密码框布局,需要一个圆角边框的shape作为layout的背景 -->
                <LinearLayout
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center_horizontal"
                    android:layout_marginTop="@dimen/dp_15"
                    android:gravity="center"
                    android:orientation="horizontal">
                    <!-- inputType设置隐藏密码明文
                    textSize设置大一点,否则“点”太小了,不美观 -->
                    <TextView
                        android:id="@+id/tv_pass1"
                        android:layout_width="@dimen/dp_15"
                        android:layout_height="@dimen/dp_15"
                        android:layout_marginLeft="@dimen/dp_10"
                        android:layout_marginRight="@dimen/dp_10"
                        android:background="@drawable/bg_circle_num_pwd"
                        android:gravity="center"
                        android:inputType="numberPassword"
                        android:paddingBottom="@dimen/dp_5"
                        android:textColor="@color/pwd_gray"
                        android:textSize="12sp"/>


                    <TextView
                        android:id="@+id/tv_pass2"
                        android:layout_width="@dimen/dp_15"
                        android:layout_height="@dimen/dp_15"
                        android:layout_marginLeft="@dimen/dp_10"
                        android:layout_marginRight="@dimen/dp_10"
                        android:background="@drawable/bg_circle_num_pwd"
                        android:gravity="center"
                        android:inputType="numberPassword"
                        android:textColor="@color/pwd_gray"
                        android:textSize="15sp"/>


                    <TextView
                        android:id="@+id/tv_pass3"
                        android:layout_width="@dimen/dp_15"
                        android:layout_height="@dimen/dp_15"
                        android:layout_marginLeft="@dimen/dp_10"
                        android:layout_marginRight="@dimen/dp_10"
                        android:background="@drawable/bg_circle_num_pwd"
                        android:gravity="center"
                        android:inputType="numberPassword"
                        android:textColor="@color/pwd_gray"
                        android:textSize="15sp"/>


                    <TextView
                        android:id="@+id/tv_pass4"
                        android:layout_width="@dimen/dp_15"
                        android:layout_height="@dimen/dp_15"
                        android:layout_marginLeft="@dimen/dp_10"
                        android:layout_marginRight="@dimen/dp_10"
                        android:background="@drawable/bg_circle_num_pwd"
                        android:gravity="center"
                        android:inputType="numberPassword"
                        android:textColor="@color/pwd_gray"
                        android:textSize="15sp"/>


                    <TextView
                        android:id="@+id/tv_pass5"
                        android:layout_width="@dimen/dp_15"
                        android:layout_height="@dimen/dp_15"
                        android:layout_marginLeft="@dimen/dp_10"
                        android:layout_marginRight="@dimen/dp_10"
                        android:background="@drawable/bg_circle_num_pwd"
                        android:gravity="center"
                        android:inputType="numberPassword"
                        android:textColor="@color/pwd_gray"
                        android:textSize="15sp"/>


                    <TextView
                        android:id="@+id/tv_pass6"
                        android:layout_width="@dimen/dp_15"
                        android:layout_height="@dimen/dp_15"
                        android:layout_marginLeft="@dimen/dp_10"
                        android:layout_marginRight="@dimen/dp_10"
                        android:background="@drawable/bg_circle_num_pwd"
                        android:gravity="center"
                        android:inputType="numberPassword"
                        android:textColor="@color/pwd_gray"
                        android:textSize="15sp"/>
                </LinearLayout>

                <TextView
                    android:id="@+id/tv_pay_forgetPwd"
                    android:layout_width="@dimen/dp_20"
                    android:layout_height="@dimen/dp_20"
                    android:textColor="@color/white"
                    android:visibility="gone"/>

            </LinearLayout>
            <!-- 输入键盘 -->
            <GridView
                android:id="@+id/gv_keybord"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_centerInParent="true"
                android:layout_marginTop="@dimen/dp_50"
                android:horizontalSpacing="0.5dp"
                android:numColumns="3"
                android:textColor="@color/colorPrimary"
                android:verticalSpacing="0.5dp"/>

            <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:orientation="horizontal"
                android:padding="@dimen/dp_10">

                <TextView
                    android:id="@+id/cancelButton"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:padding="@dimen/dp_10"
                    android:text="@string/pay_cancle"
                    android:textColor="@color/white"
                    android:textSize="@dimen/sp_15"/>

                <TextView
                    android:id="@+id/okButton"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_alignParentRight="true"
                    android:layout_gravity="right"
                    android:padding="@dimen/dp_10"
                    android:text="@string/pay_delete"
                    android:textColor="@color/white"
                    android:textSize="@dimen/sp_15"/>
            </RelativeLayout>

        </RelativeLayout>

    </LinearLayout>
</RelativeLayout>

style

  <!--  这个是popwindow -->
    <style name="mypopwindow_anim_style">
        <item name="android:windowEnterAnimation">@anim/popshow_anim</item>
        <!-- 指定显示的动画xml -->

        <item name="android:windowExitAnimation">@anim/pophidden_anim</item>
        <!-- 指定消失的动画xml -->
    </style>

popshow_anim

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:duration="500"
        android:fromYDelta="100%p"
        android:toYDelta="0" />

    <alpha
        android:duration="500"
        android:fromAlpha="0.0"
        android:toAlpha="1.0" />
</set>

pophidden_anim

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="500"
        android:fromYDelta="0"
        android:toYDelta="50%p" />

    <alpha
        android:duration="500"
        android:fromAlpha="1.0"
        android:toAlpha="0.0" />
</set>

如果大家看懂了这个,再也不怕任何自定义的弹框,根据这个原理,可以封装任意的弹框
比如看看下面类似滴滴打车的搜索页面可以用PopWindow 实现,可以自己试试。
感谢批评与指导


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,028评论 25 707
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,389评论 0 17
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,089评论 4 62
  • 01 一个阴雨绵绵的周末,我正窝在床上刷淘宝,突然听见有人敲门,问是谁,半天才听见一个带着沙哑嗓音、明显有着哭腔的...
    何初见阅读 718评论 35 29
  • 鲜酒洒满云端 像被驴血渲染的青麦 暗紫色涌动的风 分不清是黑夜还是黎明 天那边是什么? 是充满藻荇的黄河, 还是水...
    卡贝田阅读 274评论 1 2