Make sure JavaScript PhoneGap code is initialized and deviceready is fired for a new HTML page loaded from link in initial index.html.

This commit is contained in:
Bryce Curtis
2010-08-24 13:19:22 -05:00
parent 9f1730ae47
commit 13679fe00d
2 changed files with 29 additions and 4 deletions

View File

@@ -108,6 +108,8 @@ public class DroidGap extends Activity {
appView.setWebChromeClient(new GapClient(this));
}
appView.setWebViewClient(new GapViewClient(this));
appView.setInitialScale(100);
appView.setVerticalScrollBarEnabled(false);
@@ -387,7 +389,22 @@ public class DroidGap extends Activity {
}
public class GapViewClient extends WebViewClient {
Context mCtx;
public GapViewClient(Context ctx) {
mCtx = ctx;
}
public void onPageFinished (WebView view, String url) {
// Try firing the onNativeReady event in JS. If it fails because the JS is
// not loaded yet then just set a flag so that the onNativeReady can be fired
// from the JS side when the JS gets to that code.
appView.loadUrl("javascript:try{ PhoneGap.onNativeReady.fire(); console.log('FIRE!');}catch(e){_nativeReady = true; console.log('native=TRUE');}");
}
}
public boolean onKeyDown(int keyCode, KeyEvent event)
{