下面是我的堆栈跟踪:
01-30 15:11:41.037 13010-13010/project.app E/AndroidRuntime: FATAL EXCEPTION: main
Process: project.app, PID: 13010
android.view.WindowManager$BadTokenException:
Unable to add window android.view.ViewRootImpl$W@c745883 -- permission denied for window type 2003
at android.view.ViewRootImpl.setView(ViewRootImpl.java:789)
at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:356)
at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:93)
at android.app.Dialog.show(Dialog.java:330)
at com.facebook.react.devsupport.DevSupportManagerImpl$4.run(DevSupportManagerImpl.java:344)
at android.os.Handler.handleCallback(Handler.java:790)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6494)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
我找到了一个关于TYPE_SYSTEM_ERROR
在Android Oreo (8)中被弃用的答案,所以我实现了以下我也发现的方法:
public void fixAndroid() {
WindowManager.LayoutParams params;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
params = new WindowManager.LayoutParams(
WindowManager.LayoutParams.MATCH_PARENT,
WindowManager.LayoutParams.MATCH_PARENT,
WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY,
WindowManager.LayoutParams.FLAG_FULLSCREEN,
PixelFormat.TRANSLUCENT);
} else {
params = new WindowManager.LayoutParams(
WindowManager.LayoutParams.MATCH_PARENT,
WindowManager.LayoutParams.MATCH_PARENT,
WindowManager.LayoutParams.TYPE_SYSTEM_ERROR,
WindowManager.LayoutParams.FLAG_FULLSCREEN,
PixelFormat.TRANSLUCENT);
}
}
在我的onCreate()
方法中,我有:
@Override
public void onCreate (Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Checking permissions on init
fixAndroid();
}
我仍然会得到这个错误。
我使用的是Expo SDK 21,React Native 0.48。应用程序已分离到ExpoKit。
在每次更改之后,我清理我的项目,然后通过Android Studio在Emulator上运行它。
编辑:我在Nexus5X模拟器上运行,运行在API27上。
发布于 2018-02-07 23:48:52
不久前,当我将一个本机&react应用程序更新到SDK 26时,我看到了这个错误。问题出在为开发创建红色对话框的react本机函数。该函数使用TYPE_SYSTEM_ALERT作为其类型,因此您不能在具有该版本的react-native的混合应用程序中使用大于25的SDK级别,除非您为该函数打补丁,使其不再使用TYPE_SYSTEM_ALERT。
这是0.48中的react-native代码:
private void showNewError(
final String message,
final StackFrame[] stack,
final int errorCookie,
final ErrorType errorType) {
UiThreadUtil.runOnUiThread(
new Runnable() {
@Override
public void run() {
if (mRedBoxDialog == null) {
mRedBoxDialog = new RedBoxDialog(mApplicationContext, DevSupportManagerImpl.this, mRedBoxHandler);
mRedBoxDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
}
if (mRedBoxDialog.isShowing()) {
// Sometimes errors cause multiple errors to be thrown in JS in quick succession. Only
// show the first and most actionable one.
return;
}
mRedBoxDialog.setExceptionDetails(message, stack);
updateLastErrorInfo(message, stack, errorCookie, errorType);
// Only report native errors here. JS errors are reported
// inside {@link #updateJSError} after source mapping.
if (mRedBoxHandler != null && errorType == ErrorType.NATIVE) {
mRedBoxHandler.handleRedbox(message, stack, RedBoxHandler.ErrorType.NATIVE);
mRedBoxDialog.resetReporting(true);
} else {
mRedBoxDialog.resetReporting(false);
}
mRedBoxDialog.show();
}
});
}
您需要将mRedBoxDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
调用更改为其他类型。但是,这并不能保证你能够用SDK 26运行你的应用程序,当我试图用SDK 26编译react时,项目的其他部分“反应”爆炸了,所以这不太可能在短期内工作(你可能需要开始修复其他问题)。所以你的选择是:
将应用程序-Downgrade到25级;
-Upgrade到react 0.52,其中该函数不再存在,然后重试(react库在此之后可能无法工作)
-Patch react-native 0.48分支中的函数,并尝试打补丁的版本。可能会出现一些与SDK相关的其他问题(react在这一点上仍在使用SDK 22编译)
祝你编码愉快!
发布于 2018-06-11 20:26:27
TYPE_SYSTEM_ALERT
此常量在API级别26中已弃用。用于非系统应用程序。请改用TYPE_APPLICATION_OVERLAY
。
发布于 2018-02-09 02:27:24
验证SYSTEM_ALERT_WINDOW权限或尝试手动提供覆盖权限。
正如@Fco P.所说,你可以尝试改变
mRedBoxDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
如果您使用的是联想设备,请使用**##。请试一下其他的。此特定权限有时会在联想设备中出现问题。*
https://stackoverflow.com/questions/48524761
复制相似问题