Androidプログラム(WebビューのJava + html)があります。javascriptからJavaコードに呼び出すことができます。 (Eclipseで更新した後)。
これが私がやろうとしていることです
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..");
}
JavaScriptメソッドは、バックグラウンド(つまり非UI)スレッドで実行されます。すべてを呼び出す必要がありますAndroid UIスレッドで関連するメソッドを表示します。
mWebView.post(new Runnable() {
@Override
public void run() {
mWebView.loadUrl(...).
}
});
UIスレッドで実行するタスクをポストします。
私の場合、WebViewには何も表示されませんでしたので、別の方法を好みます。
runOnUiThread(new Runnable() {
@Override
public void run() {
final WebView webView = (WebView) findViewById(R.id.map);
webView.loadDataWithBaseURL(...);
}
});
これは、postメソッドを使用して実現できます。以下のコードをご覧ください。
m_targetView.post(new Runnable() {
@Override
public void run() {
m_targetView.loadUrl(".....");
}
});