使用WebView, WebChromeClient和WebViewClient加載網頁

在android應用中,有時要加載一個網頁,如果能配上一個進度條就更好了,而android 

中提供了其很好的支持,下面是一個例子程序,先帖: 

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>   
  2. <WebView xmlns:android="http://schemas.android.com/apk/res/android"   
  3. android:id="@+id/webView" android:layout_width="fill_parent"   
  4. android:layout_height="fill_parent" />   

主程序: 

[java] view plaincopy
  1. public class WebPageLoader extends Activity  
  2.   {      
  3.       final Activity activity = this;     
  4.       @Override     
  5.       public void onCreate(Bundle savedInstanceState)     
  6.       {      
  7.           super.onCreate(savedInstanceState);      
  8.           this.getWindow().requestFeature(Window.FEATURE_PROGRESS);     
  9.           setContentView(R.layout.main);    
  10.           WebView webView = (WebView) findViewById(R.id.webView);     
  11.           webView.getSettings().setJavaScriptEnabled(true);  
  12.       webView.getSettings().setSupportZoom(true);  
  13.           webView.setWebChromeClient(new WebChromeClient()   
  14.           {            
  15.               public void onProgressChanged(WebView view, int progress)     
  16.               {              
  17.                   activity.setTitle("Loading...");         
  18.                   activity.setProgress(progress * 100);       
  19.                   if(progress == 100)              
  20.                       activity.setTitle(R.string.app_name);         
  21.                   }        
  22.               }  
  23.           );        
  24.           webView.setWebViewClient(new WebViewClient() {     
  25.                        
  26.               public void onReceivedError(WebView view, int errorCode, String description, String failingUrl)     
  27.               {                 // Handle the error         
  28.                     
  29.               }               
  30.                       
  31.               public boolean shouldOverrideUrlLoading(WebView view, String url)   
  32.               {                
  33.                   view.loadUrl(url);     
  34.                   return true;         
  35.                   }        
  36.               });    
  37.           webView.loadUrl("http://www.sohu.com");    
  38.           }   
  39.       }  

要注意的是,其中的webView的一系列用法,比如 webView.getSettings().setJavaScriptEnabled(true);設置可以使用javscript; 

[java] view plaincopy
  1. webView.getSettings().setJavaScriptEnabled(true);     
  2. webView.setScrollBarStyle(WebView.SCROLLBARS_OUTSIDE_OVERLAY);     
  3. webView.setHorizontalScrollBarEnabled(false);     
  4. webView.getSettings().setSupportZoom(true);     
  5. webView.getSettings().setBuiltInZoomControls(true);     
  6. webView.setInitialScale(70);     
  7. webView.setHorizontalScrollbarOverlay(true);    

等等,具體參考API 
而進度條的使用是在new出一個setWebChromeClient後,可以在內部類中寫 
onProgressChanged事件 

在WebView的設計中,不是什麼事都要WebView類乾的,有些雜事是分給其他人的,這樣WebView專心幹好自己的解析、渲染工作就行了。WebViewClient就是幫助WebView處理各種通知、請求事件的,具體來說包括:

[java] view plaincopy
  1. onLoadResource   
  2.   
  3. onPageStart   
  4.   
  5. onPageFinish   
  6.   
  7. onReceiveError   
  8.   
  9. onReceivedHttpAuthRequest   

WebChromeClient是輔助WebView處理Javascript的對話框,網站圖標,網站title,加載進度等 :

[java] view plaincopy
  1. onCloseWindow(關閉WebView)   
  2.   
  3. onCreateWindow()   
  4.   
  5. onJsAlert (WebView上alert是彈不出來東西的,需要定製你的WebChromeClient處理彈出)   
  6.   
  7. onJsPrompt   
  8.   
  9. onJsConfirm   
  10.   
  11. onProgressChanged   
  12.   
  13. onReceivedIcon   
  14.   
  15. onReceivedTitle  

更多的時候,你可以這樣

[java] view plaincopy
  1. WebView webView;    
  2. webView= (WebView) findViewById(R.id.webview);   
  3. webView.setWebChromeClient(new WebChromeClient());    
  4. webView.setWebViewClient(new WebViewClient());    
  5. webView.getSettings().  
  6. setJavaScriptEnabled(true);   
  7. webView.loadUrl(url);    

這樣你的WebView理論上就能有大部分需要實現的特色了
當然,有些更精彩的內容還是需要你自己添加的

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