Dan*_*Dan 12 android android-manifest android-permissions react-native react-native-android
这是我的堆栈跟踪:
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)
Run Code Online (Sandbox Code Playgroud)
我找到了关于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);
}
}
Run Code Online (Sandbox Code Playgroud)
在我的onCreate()方法里面,我有:
@Override
public void onCreate (Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Checking permissions on init
fixAndroid();
}
Run Code Online (Sandbox Code Playgroud)
我仍然得到错误.
我正在使用Expo SDK 21,React Native 0.48.该应用程序已分离到ExpoKit.
每次更改后,我清理我的项目,然后通过Android Studio在模拟器上运行它.
编辑:我在Nexus 5X仿真器上运行,在API 27上运行.
不久前,当我将 Native&React 应用程序更新到 SDK 26 时,我看到了此错误。问题是 React-Native 函数创建了用于开发的红色对话框。该函数使用 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();
}
});
}
Run Code Online (Sandbox Code Playgroud)
您需要将调用更改mRedBoxDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
为其他类型。但是,这并不能保证您能够使用 SDK 26 运行您的应用程序,当我尝试使用 SDK 26 编译 React 时,项目的其他部分“反应”爆炸,因此这不太可能在短期内起作用术语(您可能需要开始解决其他问题)。所以你的选择是:
-将应用程序降级至25级;
-升级到react 0.52,该功能不再存在,然后重试(此后react库可能无法工作)
- 修补react-native 0.48分支中的功能并尝试修补的版本。可能会出现一些与 SDK 相关的其他问题(此时 React 仍在使用 SDK 22 进行编译)
快乐编码!
| 归档时间: |
|
| 查看次数: |
2582 次 |
| 最近记录: |