Android 悬浮窗相关
本篇文章主要记录下项目中遇到的关于自定义toast无法弹出的问题.
1: 错误日志
直接上日志:
2024-03-12 19:56:13.459 18475-18475/? W/System.err: android.view.WindowManager$BadTokenException: Unable to add window android.view.OplusViewRootImplHooks$ColorW@98cea23 -- permission denied for window type 2002
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.view.ViewRootImpl.setView(ViewRootImpl.java:1274)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:413)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:110)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at com.test.toasttest.CustomToast.showOff(CustomToast.java:147)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at com.test.toasttest.CustomToast.access$100(CustomToast.java:22)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at com.test.toasttest.CustomToast$FMManager.scheduleNext(CustomToast.java:103)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at com.test.toasttest.CustomToast$FMManager.show(CustomToast.java:97)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at com.test.toasttest.CustomToast.show(CustomToast.java:67)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at com.test.toasttest.MainActivity$1.onClick(MainActivity.java:21)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.view.View.performClick(View.java:7570)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at com.google.android.material.button.MaterialButton.performClick(MaterialButton.java:967)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.view.View.performClickInternal(View.java:7525)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.view.View.access$3900(View.java:836)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.view.View$PerformClick.run(View.java:28680)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.os.Handler.handleCallback(Handler.java:938)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.os.Handler.dispatchMessage(Handler.java:99)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.os.Looper.loop(Looper.java:263)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at android.app.ActivityThread.main(ActivityThread.java:8321)
2024-03-12 19:56:13.459 18475-18475/? W/System.err: at java.lang.reflect.Method.invoke(Native Method)
2024-03-12 19:56:13.460 18475-18475/? W/System.err: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:612)
2024-03-12 19:56:13.460 18475-18475/? W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1006)
2: 问题原因
项目需求,由原来的targetSdkVersion 24 升级到了28.
3: 源码
private void showOff() {
WindowManager.LayoutParams params = new WindowManager.LayoutParams();
params.gravity = Gravity.CENTER_HORIZONTAL | Gravity.BOTTOM;
params.height = WindowManager.LayoutParams.WRAP_CONTENT;
params.width = WindowManager.LayoutParams.WRAP_CONTENT;
params.flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE | WindowManager.LayoutParams.FLAG_NOT_TOUCHABLE;
params.format = PixelFormat.TRANSLUCENT;
params.windowAnimations = android.R.style.Animation_Toast;
params.y = dip2px(mContext, 64);
if (Build.VERSION.SDK_INT > 24) {
params.type = WindowManager.LayoutParams.TYPE_PHONE;
} else {
params.type = WindowManager.LayoutParams.TYPE_TOAST;
}
try {
mFloatView = getView(mContext, text);
mFloatView.setLayoutParams(params);
WindowManager manager = (WindowManager) mContext.getSystemService(Context.WINDOW_SERVICE);
manager.addView(mFloatView, params);
} catch (Throwable e) {
e.printStackTrace();
}
}
4: 解决办法
需要适配Build.VERSION_CODES.O:
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
params.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;
}else if (Build.VERSION.SDK_INT > 24) {
params.type = WindowManager.LayoutParams.TYPE_PHONE;
} else {
params.type = WindowManager.LayoutParams.TYPE_TOAST;
}