У меня есть программа для Android (Java + html в веб-просмотре). Я могу позвонить из javascript в код Java. Но наоборот перестал работать (после обновления в eclipse).
Так вот что я пытаюсь сделать
- Сделать веб-просмотр (работал)
- вызов в javascript для AndroidFunction.test (); (работал)
- вызов функции java test () webView.loadUrl ("javascript: helloBack ()"); (! больше не работает)
Я попытался позволить ему работать с WebView в MainActivity, но это не сработало.
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
android
android-webview
Йохан Хуксма
источник
источник
Ответы:
Метод JavaScript выполняется в фоновом (т. Е. Не UI) потоке. Вам необходимо вызвать все методы, связанные с Android View, в потоке пользовательского интерфейса. Вы можете добиться того, что вам нужно:
mWebView.post(new Runnable() { @Override public void run() { mWebView.loadUrl(...). } });
Который опубликует задачу для запуска в потоке пользовательского интерфейса.
источник
В моем случае в 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("....."); } });
источник
Версия Java : необходимо использовать интерфейс Runnable и Post to Handler .
webView.post(new Runnable() { @Override public void run() { webView.loadUrl("file:///android_asset/www/index.html"); } });
Версия Котлина :
webView.post(new Runnable { webView.loadUrl("file:///android_asset/www/index.html") })
источник