版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_21983189/article/details/60141582
如今大部分应用为了让用户时刻注意到自己应用的特殊功能,或者告诉用户一些提示性的信息时,这时候假如用户退出了我们的应用,那么我们可以显示出一个系统级别的悬浮框,达到用户快捷操作和进入我们应用的效果,那么我们则利用android自带的WindowManager控件实现:
public class WindowUtils {
private static final String LOG_TAG = "WindowUtils";
private static View mView = null;
private static WindowManager mWindowManager = null;
public static Boolean isShown = false;
/**
* 显示弹出框
*
* @param context
*/
public static void showPopupWindow(final Context context) {
if (isShown) {
Log.i(LOG_TAG, "return cause already shown");
return;
}
isShown = true;
Log.i(LOG_TAG, "showPopupWindow");
// 获取应用的Context,注意这里的上下文环境必须是ApplicationContext级别的,否则显示不出来;接着得到WindowManager对象
mWindowManager = (WindowManager) context.getApplicationContext().getSystemService(Context.WINDOW_SERVICE);
mView = LayoutInflater.from(context).inflate(R.layout.layout_back, null);
;
final WindowManager.LayoutParams params = new WindowManager.LayoutParams();
// 类型
params.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;
// WindowManager.LayoutParams.TYPE_SYSTEM_ALERT
// 设置flag
int flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;
// | WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;
// 如果设置了WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE,弹出的View收不到Back键的事件
params.flags = flags;
// 不设置这个弹出框的透明遮罩显示为黑色
params.format = PixelFormat.TRANSLUCENT;
// FLAG_NOT_TOUCH_MODAL不阻塞事件传递到后面的窗口
// 设置 FLAG_NOT_FOCUSABLE 悬浮窗口较小时,后面的应用图标由不可长按变为可长按
// 不设置这个flag的话,home页的划屏会有问题
params.width = WindowManager.LayoutParams.WRAP_CONTENT;
params.height = WindowManager.LayoutParams.WRAP_CONTENT;
//位置
params.gravity = Gravity.TOP | Gravity.LEFT;
mWindowManager.addView(mView, params);
Log.i(LOG_TAG, "add view");
}
/**
* 隐藏弹出框
*/
public static void hidePopupWindow() {
Log.i(LOG_TAG, "hide " + isShown + ", " + mView);
if (isShown && null != mView) {
Log.i(LOG_TAG, "hidePopupWindow");
mWindowManager.removeView(mView);
isShown = false;
}
}
}
最后注意在manifest.xml中增加权限:
<uses-permissionandroid:name="android.permission.SYSTEM_ALERT_WINDOW" />