The following example demonstarte this:
Step 1: Create a new Android project "JavascriptDemo" in Eclipse. A html web page is created in the assests directory.
Step 2: Modify activity_javascript_demo.xml layout document. Add a button in the WebView
<LinearLayout xmlns:android=
"http://schemas.android.com/apk/res/android"
android:orientation=
"vertical"
android:layout_width=
"fill_parent"
android:layout_height=
"fill_parent"
>
<TextView
android:layout_width=
"fill_parent"
android:layout_height=
"wrap_content"
android:text=
"Hello World!!"
/>
<WebView
android:id=
"@+id/webview"
android:layout_width=
"fill_parent"
android:layout_height=
"wrap_content"
/>
<Button
android:id=
"@+id/button"
android:layout_width=
"fill_parent"
android:layout_height=
"wrap_content"
android:text=
"Change the webview content"
/>
</LinearLayout>
Step 3: Create a demo.html file under assest directory.
<html>
<script language=
"javascript"
><!--
function fillContent(){
document.getElementById(
"content"
).innerHTML =
"This Content is showed by Android invoked Javascript function."
;
}
// --></script>
<body>
<p><a onClick=
"window.demo.startMap()"
href=
""
>Start GoogleMap</a></p>
<p id=
"content"
></p>
<p>EasyInfoGeek.com</p>
<p>Javscript Demo ---- Android and Javascript interaction</p>
</body>
</html>
Step 4: Modify JavascriptDemo.java
package com.easyinfogeek.javascriptdemo; import android.app.Activity; import android.content.ComponentName; import android.content.Intent; import android.os.Bundle; import android.view.Menu; import android.view.View; import android.webkit.WebSettings; import android.webkit.WebView; import android.widget.Button; public class JavascriptDemo extends Activity { private WebView mWebView; private Button mButton; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_javascript_demo); setupViews(); } private void setupViews() { mWebView = (WebView) findViewById(R.id.webview); WebSettings mWebSettings = mWebView.getSettings(); mWebSettings.setJavaScriptEnabled(true); mWebView.addJavascriptInterface(new Object() { public void startMap() { Intent mIntent = new Intent(); ComponentName component = new ComponentName( "com.google.android.apps.maps", "com.google.android.maps.MapsActivity"); mIntent.setComponent(component); startActivity(mIntent); } }, "demo"); mWebView.loadUrl("file:///android_asset/demo.html"); mButton = (Button) findViewById(R.id.button); mButton.setOnClickListener(new Button.OnClickListener() { public void onClick(View v) { mWebView.loadUrl("javascript:fillContent()"); } }); } }
No comments:
Post a Comment