我是靠谱客的博主 真实苗条,最近开发中收集的这篇文章主要介绍如何封装一个通用的PopupWindow,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述


PopupWindow 这个类用来实现一个弹出框,可以使用任意布局的 View 作为其内容,这个弹出框是悬浮在当前 activity 之上的。

一般 PopupWindow 的使用:

上面就是 PopupWindow 通常需要设置的各个方法,不难,但是稍微有点繁琐,有些是可以复用的,所以封装了一个通用的 CommonPopupWindow:

CommonPopupWindow 继承自 PopupWindow,拥有 PopupWindow 的各个属性方法,使用类似建造者模式,和 AlertDialog 的使用方式差不多,CommonPopupWindow 使用举例:

  • CommonPopupWindow 设置背景

这里使用的是 WindowManager.LayoutParams.alpha 属性,看下官网解释:An alpha value to apply to this entire window. An alpha of 1.0 means fully opaque and 0.0 means fully transparent .

alpha 值适用于整个 Window,α 为 1.0 时表示完全不透明而0.0表示完全透明,默认是1.0,当 PopupWindow 弹出时通过设置 alpha 在(0.0,1.0)之间设置灰色背景,当 PopupWindow 消失时恢复默认值。

  • 计算 CommonPopupWindow 宽高

注:在测量宽高时遇到一种情况,如图所示:

如果设置 TextView 的 android:layout_width="wrap_content",那么测量不出 TextView 准确的 height,当设置 width 为某个确定值时,也能得到准确的 height 了。

  • CommonPopupWindow 设置动画

如设置向右动画:

.setAnimationStyle(R.style.AnimHorizontal);

在 style.xml 文件中设置:

android:windowEnterAnimation、android:windowExitAnimation 分别为 Popupwindow 弹出和消失动画

进入动画为anim目录下的 push_scale_left_in.xml

消失动画为 push_scale_left_out.xml

  • CommonPopupWindow 弹出

因为 CommonPopupWindow 继承自 PopupWindow,所以可以直接使用 PopupWindow 中的弹出方法,常用的下面三种:

其中,showAsDropDown 是显示在参照物anchor的周围,xoff、yoff 分别是X轴、Y轴的偏移量,如果不设置 xoff、yoff,默认是显示在 anchor 的下方;showAtLocation 是设置在父控件的位置,如设置 Gravity.BOTTOM 表示在父控件底部弹出,xoff、yoff 也是X轴、Y轴的偏移量。

如上面向右弹出例子,分别使用 showAsDropDown 和 showAtLocation 来实现:

showAsDropDown:

popupWindow.showAsDropDown(view, view.getWidth(), -view.getHeight());

showAsDropDown 默认展示在 button 的下面,通过改变 X轴 和 Y轴 的偏移量(X轴向右偏移 button 的宽度,Y轴向上偏移 button 的高度),实现在 Button 右边弹出。

showAtLocation:

使用了 View 的 getLocationOnScreen方法 来获得View在屏幕中的坐标位置,传入的参数必须是一个有2个整数的数组,分别代表 View 的X、Y坐标,即是 View 的左上角的坐标,这里的 View 是 Button,知道了 Button 左上角的坐标,就可以得到要展示的 PopupWindow 的左上角的坐标为 (positions[0] + view.getWidth(), positions[1]),从而实现在 Button 右边弹出。

最后

以上就是真实苗条为你收集整理的如何封装一个通用的PopupWindow的全部内容,希望文章能够帮你解决如何封装一个通用的PopupWindow所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部