web-dev-qa-db-ja.com

android.view.WindowManager $ BadTokenException:ウィンドウを追加できませんAndroid.view.ViewRootImpl $ W @ c745883-権限が拒否されました

これが私のスタックトレースです:

_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 Native0.48を使用しています。アプリケーションはExpoKitにデタッチされています。

変更するたびに、プロジェクトをクリーンアップしてから、Android Studioを介してエミュレーターで実行します。

編集:API27で実行されているNexus5Xエミュレーターでこれを実行しています。

12
Dan
TYPE_SYSTEM_ALERT

この定数は、システム以外のアプリのAPIレベル26で非推奨になりました。使用する TYPE_APPLICATION_OVERLAY代わりに。

1
Elad

少し前に、native&reactアプリをSDK 26に更新したときに、このエラーが発生しました。問題は、開発用の赤いダイアログを作成するreact-native関数です。その関数はタイプとしてTYPE_SYSTEM_ALERTを使用するため、その関数にパッチを適用してTYPE_SYSTEM_ALERTを使用しないようにしない限り、そのバージョンのreact-nativeを使用するハイブリッドアプリで25を超えるSDKレベルを使用することはできません。

これは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でアプリを実行できることを保証するものではありません。SDK26でreactをコンパイルしようとすると、プロジェクトの他の部分が「reacted」爆発するため、これは簡単には機能しない可能性があります。期間(他の問題の修正を開始する必要がある場合があります)。したがって、オプションは次のとおりです。

-アプリをレベル25にダウングレードします。

-その関数が存在しなくなった0.52にreactにアップグレードして、再試行します(reactライブラリはこの後機能しない場合があります)

-react-native 0.48ブランチに関数をパッチし、パッチを適用したバージョンを試してください。 SDKに関連する他のいくつかの問題が発生する可能性があります(この時点での反応はまだSDK 22でコンパイルされています)

ハッピーコーディング!

0
Fco P.

SYSTEM_ALERT_WINDOW権限を確認するか、オーバーレイ権限を手動で提供してみてください。

@Fco P.が言ったように、あなたは変更を試みることができます

mRedBoxDialog.getWindow()。setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);

** ## Lenovoデバイスを使用している場合。別のもので試してみてください。この特定の権限により、Lenovoデバイスで問題が発生することがあります。****

0
Dipendra Sharma