同じスレッドエラーのWebViewメソッド


84

私はAndroidプログラム(WebビューのJava + html)を持っています。javascriptからJavaコードを呼び出すことができます。しかし、その逆は(Eclipseで更新した後)動作を停止しました。

だからこれが私がやろうとしていることです

  • Webビューを作成する(機能)
  • JavaScriptでAndroidFunction.test();を呼び出す (働いた)
  • java test()関数呼び出しwebView.loadUrl( "javascript:helloBack()"); (!もう動作していません)

MainActivityのWebViewで動作させようとしましたが、動作しませんでした。

MainActivity.java

public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        final WebView webView = (WebView)findViewById(R.id.webView);
        webView.getSettings().setJavaScriptEnabled(true);
        webView.setWebChromeClient(new WebChromeClient());
        WebSettings webSettings = webView.getSettings();
        webSettings.setJavaScriptEnabled(true);

        javascr = new Javascript(this, webView);
        webView.addJavascriptInterface(javascr, "AndroidFunction");
        webView.loadUrl("file:///android_asset/www/index.html");

        ....
}

Javascript.java

public class Javascript {   
    Context cont;
    WebView webView;

    Javascript(Context c, WebView w) {
        cont = c;
        webView = w;
    }

    // function called in the javascript by AndroidFunction.test();
    public void test() {
          // Breaking point!!!
        webView.loadUrl("javascript:helloBack()");
    }

エラー:

03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
03-24 11:47:50.103: W/WebView(21026):   java.lang.Throwable: A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same thread. (Expected Looper Looper{41ab68f8} called on Looper{41bb70a8}, FYI main Looper is Looper{41ab68f8})

03-24 11:47:50.103: W/WebView(21026):   at android.webkit.WebView.checkThread(WebView.java:2063)
03-24 11:47:50.103: W/WebView(21026):   at android.webkit.WebView.loadUrl(WebView.java:794)
03-24 11:47:50.103: W/WebView(21026):   at com.example.hellobt.Javascript.test(Javascript.java:24)

03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.nativeDoRunLoopOnce(Native Method)
03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
03-24 11:47:50.103: W/WebView(21026):   at android.os.Handler.dispatchMessage(Handler.java:102)

03-24 11:47:50.103: W/WebView(21026):   at android.os.Looper.loop(Looper.java:137)
03-24 11:47:50.103: W/WebView(21026):   at android.os.HandlerThread.run(HandlerThread.java:61)

答えてくれてありがとう。Javascriptファイルの関数を次のように編集しました。

private void test(final String s) {
        webView.post(new Runnable() {
            public void run() {
                webView.loadUrl("javascript:" + s + ";");
            }
        });
        System.out.println("javscript done..");
    }

あなたの編集で、あなたは答え(の1つ)に基づいてコードを変更したと述べていますが、これはまだ問題を解決していないように聞こえますが、受け入れられた答えがあります。これで問題が解決したかどうかを明示することをお勧めします(または、編集を元に戻すだけです)。
トム

回答:


212

JavaScriptメソッドは、バックグラウンド(つまり非UI)スレッドで実行されます。UIスレッドですべてのAndroidView関連メソッドを呼び出す必要があります。あなたはあなたが必要とするものを達成することができます:

mWebView.post(new Runnable() {
    @Override
    public void run() {
        mWebView.loadUrl(...).
    }
});

これは、UIスレッドで実行するタスクを投稿します。


スニペット(mWebView)を元のコードのどこに追加しましたか?
ボウイ

test()関数で、上記の質問を参照してください。
Johan Hoeksma 2014

値を返す必要がある場合はどうなりますか?例:webview.getUrlを返しますか?stackoverflow.com/questions/29748782/…@JohanHoeksma–
Suresh Subedi

この問題がいつどのように発生したか知っていますか?Nexus 5X(Android 7.1.1)では問題ありませんが、一部のデバイスがクラッシュしました。
Ellie Zou 2016

変数を渡す方法は?mWebView.loadUrl( "javascript:test( '" + MyData + "');");に変数を追加しようとしました。しかし、値がjavascriptに渡されることはありません!
user1788736 2017

14

私の場合、WebViewには何も表示されなかったので、別の方法を好みます。

runOnUiThread(new Runnable() {
    @Override
    public void run() {
        final WebView webView = (WebView) findViewById(R.id.map);
        webView.loadDataWithBaseURL(...);
    }
});

3

これは、postメソッドを使用して解決できます。以下のコードを実行してください。

 m_targetView.post(new Runnable() {
                        @Override
                        public void run() {
                            m_targetView.loadUrl(".....");
                        }
                    });

2

Javaバージョン:あなたが使用する必要がありますのRunnableへのインタフェースとポストをハンドラ

webView.post(new Runnable() {
          @Override
          public void run() {
             webView.loadUrl("file:///android_asset/www/index.html");
          }
       });

Kotlinバージョン:

webView.post(new Runnable {
   webView.loadUrl("file:///android_asset/www/index.html")
})
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.