Я разрабатываю приложение, основанное на телефонном разрыве, и мне также нужно вызвать javascript из собственного кода Java, и наоборот
Поэтому я добавил JavascriptInterface в действие droidGap (appView.addJavascriptInterface).Но каждый раз, когда я вызываю javascript из java с помощью loadUrl ("javascript: alert ('Hello')"), через несколько секунд возникает ошибка:
/PhoneGapLog( 2839): file:///android_asset/phonegap.js: Line 930 : JSCallback Error:
Request failed.
I/Web Console( 2839): JSCallback Error: Request failed. at
file:///android_asset/phonegap.js:930
И затем, еще несколько секунд спустя,сбой приложения, с
E/WindowManager( 2839): Activity com.package.act has leaked
window com.android.internal.policy.impl.PhoneWindow$DecorView@2afbfb08 that was
originally added here
E/WindowManager( 2839): android.view.WindowLeaked: Activity
com.package.act has leaked window
com.android.internal.policy.impl.PhoneWindow$DecorView@2afbfb08 that was originally added here
E/WindowManager( 2839): at android.view.ViewRoot.<init>(ViewRoot.java:265)
E/WindowManager( 2839): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
E/WindowManager( 2839): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
E/WindowManager( 2839): at android.view.Window$LocalWindowManager.addView(Window.java:424)
E/WindowManager( 2839): at android.app.Dialog.show(Dialog.java:241)
E/WindowManager( 2839): at android.app.AlertDialog$Builder.show(AlertDialog.java:816)
E/WindowManager( 2839): at com.phonegap.DroidGap$6.run(DroidGap.java:1483)
E/WindowManager( 2839): at android.os.Handler.handleCallback(Handler.java:587)
E/WindowManager( 2839): at android.os.Handler.dispatchMessage(Handler.java:92)
E/WindowManager( 2839): at android.os.Looper.loop(Looper.java:123)
E/WindowManager( 2839): at android.app.ActivityThread.main(ActivityThread.java:3701)
E/WindowManager( 2839): at java.lang.reflect.Method.invokeNative(Native Method)
E/WindowManager( 2839): at java.lang.reflect.Method.invoke(Method.java:507)
E/WindowManager( 2839): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)
E/WindowManager( 2839): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:624)
E/WindowManager( 2839): at dalvik.system.NativeStart.main(Native Method)
Вот мой код:
public class Bukkett extends DroidGap {
private JavascriptInterface itf;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
super.init();
itf = new JavascriptInterface();
appView.addJavascriptInterface(itf, "Interface");
this.setIntegerProperty("loadUrlTimeoutValue", 70000);
super.loadUrl("file:///android_asset/html/index.html");
}
public class JavascriptInterface {
public void sayHello() {
loadUrl("javascript:alert('hello');");
}
}
}
В моем файле .js я просто звоню
if (window.Interface)
window.Interface.sayHello();
Предупреждающее сообщение хорошоотображается, но после этого происходит сбой приложения.