利用HTML5開發Android筆記(中篇)

iSmart-艾思www.smartmobi.com.cn

● Android與JS之間的互相調用交互

WebView默認是禁用JavaScript的,在啓用後,就可以在兩者間建立接口進行調用

 

Java代碼  收藏代碼
  1. WebView myWebView = (WebView) findViewById(R.id.webview);  
  2. WebSettings webSettings = myWebView.getSettings();  
  3. webSettings.setJavaScriptEnabled(true);  

 

(這裏的webSetting用處非常大 可以開啓很多設置 在之後的本地存儲,地理位置等之中都會使用到)

 

1 在JS中調用Android的函數方法

 

首先 需要在Android程序中建立接口

 

Java代碼  收藏代碼
  1. final class InJavaScript {  
  2.        public void runOnAndroidJavaScript(final String str) {  
  3.         handler.post(new Runnable() {  
  4.                public void run() {   
  5.                    TextView show = (TextView) findViewById(R.id.textview);  
  6.                    show.setText(str);  
  7.                }  
  8.            });  
  9.        }  
  10.    }  

 

 

 

Java代碼  收藏代碼
  1. //把本類的一個實例添加到js的全局對象window中,  
  2. //這樣就可以使用window.injs來調用它的方法  
  3. webView.addJavascriptInterface(new InJavaScript(), “injs”);  

 

在JavaScript中調用

 

Js代碼  收藏代碼
  1. function sendToAndroid(){  
  2.         var str = “Cookie call the Android method from js”;  
  3.         window.injs.runOnAndroidJavaScript(str);//調用android的函數  
  4. }  

 

2 在Android中調用JS的方法

 

JS中的方法

 

Js代碼  收藏代碼
  1. function getFromAndroid(str){  
  2.         document.getElementById(“android”).innerHTML=str;  
  3. }  

 

Android調用該方法

 

Java代碼  收藏代碼
  1. Button button = (Button) findViewById(R.id.button);  
  2.        button.setOnClickListener(new OnClickListener() {  
  3.        public void onClick(View arg0) {  
  4.             //調用javascript中的方法  
  5.            webView.loadUrl(“javascript:getFromAndroid(‘Cookie call the js function from Android’)”);  
  6.        }  
  7.    });  

 

3 Android中處理JS的警告,對話框等

在Android中處理JS的警告,對話框等需要對WebView設置WebChromeClient對象

 

Java代碼  收藏代碼
  1. //設置WebChromeClient  
  2. webView.setWebChromeClient(new WebChromeClient(){  
  3.     //處理javascript中的alert  
  4.     public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {  
  5.         //構建一個Builder來顯示網頁中的對話框  
  6.         Builder builder = new Builder(MainActivity.this);  
  7.         builder.setTitle(“Alert”);  
  8.         builder.setMessage(message);  
  9.         builder.setPositiveButton(android.R.string.ok,  
  10.             new AlertDialog.OnClickListener() {  
  11.                 public void onClick(DialogInterface dialog, int which) {  
  12.                     result.confirm();  
  13.                 }  
  14.             });  
  15.         builder.setCancelable(false);  
  16.         builder.create();  
  17.         builder.show();  
  18.         return true;  
  19.     };  
  20.     //處理javascript中的confirm  
  21.     public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) {  
  22.         Builder builder = new Builder(MainActivity.this);  
  23.         builder.setTitle(“confirm”);  
  24.         builder.setMessage(message);  
  25.         builder.setPositiveButton(android.R.string.ok,  
  26.             new AlertDialog.OnClickListener() {  
  27.                 public void onClick(DialogInterface dialog, int which) {  
  28.                     result.confirm();  
  29.                 }  
  30.             });  
  31.         builder.setNegativeButton(android.R.string.cancel,  
  32.             new DialogInterface.OnClickListener() {  
  33.                 public void onClick(DialogInterface dialog, int which) {  
  34.                     result.cancel();  
  35.                 }  
  36.             });  
  37.         builder.setCancelable(false);  
  38.         builder.create();  
  39.         builder.show();  
  40.         return true;  
  41.     };  
  42.           
  43.     @Override  
  44.     //設置網頁加載的進度條  
  45.     public void onProgressChanged(WebView view, int newProgress) {  
  46.         MainActivity.this.getWindow().setFeatureInt(Window.FEATURE_PROGRESS, newProgress * 100);  
  47.         super.onProgressChanged(view, newProgress);  
  48.     }  
  49.   
  50.     //設置應用程序的標題title  
  51.     public void onReceivedTitle(WebView view, String title) {  
  52.         MainActivity.this.setTitle(title);  
  53.         super.onReceivedTitle(view, title);  
  54.     }  
  55. });  

 

● Android中的調試

通過JS代碼輸出log信息

 

Js代碼  收藏代碼
  1. Js代碼: console.log(“Hello World”);  
  2. Log信息: Console: Hello World http://www.example.com/hello.html :82   

 

在WebChromeClient中實現onConsoleMesaage()回調方法,讓其在LogCat中打印信息

 

Java代碼  收藏代碼
  1. WebView myWebView = (WebView) findViewById(R.id.webview);  
  2. myWebView.setWebChromeClient(new WebChromeClient() {  
  3.     public void onConsoleMessage(String message, int lineNumber, String sourceID) {  
  4.         Log.d(“MyApplication”, message + “ – From line ”  
  5.             + lineNumber + “ of ”  
  6.             + sourceID);  
  7.     }  
  8. });  

以及

 

Java代碼  收藏代碼
  1. WebView myWebView = (WebView) findViewById(R.id.webview);  
  2. myWebView.setWebChromeClient(new WebChromeClient() {  
  3.     public boolean onConsoleMessage(ConsoleMessage cm) {  
  4.         Log.d(“MyApplication”, cm.message() + “ – From line ”  
  5.             + cm.lineNumber() + “ of ”  
  6.             + cm.sourceId() );  
  7.         return true;  
  8.     }  
  9. });  

 

*ConsoleMessage 還包括一個 MessageLevel 表示控制檯傳遞信息類型。 您可以用messageLevel()查詢信息級別,以確定信息的嚴重程度,然後使用適當的Log方法或採取其他適當的措施。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章