Android开发:自己开发的一款通用弹窗库

基于popupWindow制作了这个库,可以实现在按钮下面弹出弹窗,在按钮上面弹出弹窗,或者在页面的底部或者顶部弹出弹窗,弹窗都带有动画效果,另外默认点击弹窗外面区域,自动关闭弹窗,也可以关闭该功能,请先看效果图:

这里写图片描述

使用方法

  • 添加依赖
dependencies {
    compile 'cn.weidongjian.android:popupWindowHelper:0.5'
}

在项目的build.gradle中添加如上一行代码,就可以把库文件包含在你的项目中了

  • 初始化
private PopupWindowHelper popupWindowHelper;
private View popView;
popView = LayoutInflater.from(this).inflate(R.layout.popupview, null);
        popupWindowHelper = new PopupWindowHelper(popView);

popView就是要弹窗的视图,可以自己在xml中定义

  • 在按钮的上方显示弹窗
popupWindowHelper.showAsPopUp(view);

其中view接受点击事件的按钮

  • 在按钮的下方显示弹窗
popupWindowHelper.showAsDropDown(view);

这个调用的是popupWindow的原生方法,没什么可说的

  • 从顶部下拉显示
popupWindowHelper.showFromTop(view);
  • 从底部弹出显示
popupWindowHelper.showFromBottom(v);

另外还保留的原生的popupwindow方法

  • 设置是否要在弹出外区域点击关闭弹窗(默认是true)
/**
     * touch outside dismiss the popupwindow, default is ture
     * @param isCancelable
     */
    public void setCancelable(boolean isCancelable) {
        this.isCancelable = isCancelable;
    }

源码分析

首先,showAsDropDown是原生的方法,没什么好说的,至于showAsPopUp的方法(在按钮的上面弹出窗口),请看代码

public void showAsPopUp(View anchor) {
        showAsPopUp(anchor, 0, 0);
    }

    public void showAsPopUp(View anchor, int xoff, int yoff) {
        initPopupWindow(TYPE_WRAP_CONTENT);
        mPopupWindow.setAnimationStyle(R.style.AnimationUpPopup);
        popupView.measure(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
        int height = popupView.getMeasuredHeight();
        int[] location = new int[2];
        anchor.getLocationInWindow(location);
        mPopupWindow.showAtLocation(anchor, Gravity.LEFT | Gravity.TOP, location[0] + xoff, location[1] - height + yoff);
    }

先初始化popupwindow,然后通过setAnimationStyle设置动画效果,接着用measure测量该View的高度,最后显示还是用showAtLocation的方法显示

从顶部弹出和从底部弹出,也用的是类似的方法,不够在初始化的时候,width使用的是Match_parent的属性,另外动画效果也做了对应的修改,代码很简单,请看

public void showFromBottom(View anchor) {
        initPopupWindow(TYPE_MATCH_PARENT);
        mPopupWindow.setAnimationStyle(R.style.AnimationFromButtom);
        mPopupWindow.showAtLocation(anchor, Gravity.LEFT | Gravity.BOTTOM, 0, 0);
    }

    public void showFromTop(View anchor) {
        initPopupWindow(TYPE_MATCH_PARENT);
        mPopupWindow.setAnimationStyle(R.style.AnimationFromTop);
        mPopupWindow.showAtLocation(anchor, Gravity.LEFT | Gravity.TOP, 0, getStatusBarHeight());
    }

写这个库的时候,一般想的是尽量用最简单的方法实现,代码量也很少,且使用起来也很方便,如有什么问题,欢迎指正

项目源码请点击这里
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值