webview的具體設置與使用

webview的使用
webview加載網頁之後可以顯示網頁內容,但是在點擊網頁之後還需要JavaScript的支持,所以還需要設計JavaScript,否則顯示的會是空白的頁面
mWebView.getSettings().setJavaScriptEnabled(true);
設置完JavaScript之後再加載網頁的路徑
在點擊網頁上的內容如果不進行設置的話就會自動去到瀏覽器裏面了,所以我們需要設置一個webviewclient的客戶端

// 爲了繼續在WebView中顯示,需要重寫shouldOverrideUrlLoading方法  
    mWebView.setWebViewClient(new MyWebViewClient()); 
        
 
    。。。。。。。。。。。。。。。。。。。。。。。。         
       } 
 
private class MyWebViewClient extends WebViewClient { 
    @Override 
    public boolean shouldOverrideUrlLoading(WebView view, String url) { 
        view.loadUrl(url); 
        return true; 
    } 

 @Override
 public void onCreate(Bundle savedInstanceState) {

  。。。。。。。。。。。。。。。。。。。。。。。。               

  // 雖然Google主頁在WebView中顯示了,但是如果點擊鏈接繼續瀏覽,則會顯示到系統默認的Browser中
  // 爲了繼續在WebView中顯示,需要重寫shouldOverrideUrlLoading方法
  mWebView.setWebViewClient(new MyWebViewClient());
       

  。。。。。。。。。。。。。。。。。。。。。。。。       
        }

 private class MyWebViewClient extends WebViewClient {
  @Override
  public boolean shouldOverrideUrlLoading(WebView view, String url) {
   view.loadUrl(url);
   return true;
  }
 }

另外,如果想按回退鍵回到上一個頁面,那麼

[java]  /**
 * 按back鍵可以回到上個網頁
 */ 
@Override 
public boolean onKeyDown(int keyCode, KeyEvent event) { 
    if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) { 
        mWebView.goBack(); 
        return true; 
    } 
    return super.onKeyDown(keyCode, event); 

/**
 * 按back鍵可以回到上個網頁
 */
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
 if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {
  mWebView.goBack();
  return true;
 }
 return super.onKeyDown(keyCode, event);
}
對於Android 2.0開始又多出了一種新的方法,對於Activity 可以單獨獲取Back鍵的按下事件,直接重寫onBackPressed 方法即可,代碼如下

[java] @Override 
public void onBackPressed() { 
 // 這裏處理邏輯代碼,該方法僅適用於2.0或更高版本的sdk  
return ; 

@Override
public void onBackPressed() {
 // 這裏處理邏輯代碼,該方法僅適用於2.0或更高版本的sdk
return ;
}
如果想加載工程中的HTML,那麼可以用到下面的方法(前提是HTML放在assets目錄中)

[java]  mWebView.loadUrl("file:///android_asset/test.html"); 
mWebView.loadUrl("file:///android_asset/test.html");
如果想直接load一段HTML文,可以用下面的方法

[java]  mWebView.loadData("<html><body>abcdefg</body></html>", "text/html", "utf-8"); 
mWebView.loadData("<html><body>abcdefg</body></html>", "text/html", "utf-8");
下面是WebView其他的一下用法:

設置允許訪問文件數據

[java] mWebView.getSettings().setAllowFileAccess(true); 
mWebView.getSettings().setAllowFileAccess(true);
設置支持縮放

[java] mWebView.getSettings().setBuiltInZoomControls(true); 
mWebView.getSettings().setBuiltInZoomControls(true);
設置是否保存密碼

[java] mWebView.getSettings().setSavePassword(false); 
mWebView.getSettings().setSavePassword(false);
設置支持各種不同的設備

[java] mWebView.getSettings().setUserAgentString("Mozilla/5.0 (iPad; U; CPU OS 3_2 like Mac OS X;en-us) AppleWebKit/531.21.10 (KHTML, like Gecko) Version/4.0.4 Mobile/7B334bSafari/531.21.10"); 
mWebView.getSettings().setUserAgentString("Mozilla/5.0 (iPad; U; CPU OS 3_2 like Mac OS X;en-us) AppleWebKit/531.21.10 (KHTML, like Gecko) Version/4.0.4 Mobile/7B334bSafari/531.21.10");
加載webview網頁時所要執行的一些方法

[java] mWebView.setWebViewClient(new WebViewClient() { 
        // 新開頁面時用自己定義的webview來顯示,不用系統自帶的瀏覽器來顯示  
        @Override 
        public boolean shouldOverrideUrlLoading(WebView view, String url) { 
            view.loadUrl(url); 
            return true; 
        } 
         
        // 開始加載網頁時要做的工作  
        @Override 
        public void onPageStarted(WebView view, String url, Bitmap favicon) { 
            super.onPageStarted(view, url, favicon); 
        } 
         
        // 加載完成時要做的工作  
        @Override 
        public void onPageFinished(WebView view, String url) { 
            super.onPageFinished(view, url); 
        } 
         
        // 加載錯誤時要做的工作  
        @Override 
        public void onReceivedError(WebView view, int errorCode, 
                String description, String failingUrl) { 
            super.onReceivedError(view, errorCode, description, failingUrl); 
        } 
    }); 
mWebView.setWebViewClient(new WebViewClient() {
  // 新開頁面時用自己定義的webview來顯示,不用系統自帶的瀏覽器來顯示
  @Override
  public boolean shouldOverrideUrlLoading(WebView view, String url) {
   view.loadUrl(url);
   return true;
  }
  
  // 開始加載網頁時要做的工作
  @Override
  public void onPageStarted(WebView view, String url, Bitmap favicon) {
   super.onPageStarted(view, url, favicon);
  }
  
  // 加載完成時要做的工作
  @Override
  public void onPageFinished(WebView view, String url) {
   super.onPageFinished(view, url);
  }
  
  // 加載錯誤時要做的工作
  @Override
  public void onReceivedError(WebView view, int errorCode,
    String description, String failingUrl) {
   super.onReceivedError(view, errorCode, description, failingUrl);
  }
 });
處理網頁中的一些對話框信息(提示對話框,帶選擇的對話框,帶輸入的對話框)

[java] mWebView.setWebChromeClient(new WebChromeClient() { 
        // 提示對話框  
        @Override 
        public boolean onJsAlert(WebView view, String url, String message, 
                final JsResult result) { 
            // 構建一個Builder來顯示網頁中的alert對話框  
            Builder builder = new Builder(WebViewDemoActivity.this); 
            builder.setTitle("提示對話框"); 
            builder.setMessage(message); 
            builder.setPositiveButton(android.R.string.ok, 
                    new AlertDialog.OnClickListener() { 
                        @Override 
                        public void onClick(DialogInterface dialog, 
                                int which) { 
                            result.confirm(); 
                        } 
                    }); 
            builder.setCancelable(false); 
            builder.create(); 
            builder.show(); 
            return true; 
        } 
 
        // 帶按鈕的對話框  
        @Override 
        public boolean onJsConfirm(WebView view, String url, 
                String message, final JsResult result) { 
            Builder builder = new Builder(WebViewDemoActivity.this); 
            builder.setTitle("帶選擇的對話框"); 
            builder.setMessage(message); 
            builder.setPositiveButton(android.R.string.ok, 
                    new AlertDialog.OnClickListener() { 
                        @Override 
                        public void onClick(DialogInterface dialog, 
                                int which) { 
                            result.confirm(); 
                        } 
                    }); 
            builder.setNeutralButton(android.R.string.cancel, 
                    new AlertDialog.OnClickListener() { 
                        @Override 
                        public void onClick(DialogInterface dialog, 
                                int which) { 
                            result.cancel(); 
                        } 
                    }); 
            builder.setCancelable(false); 
            builder.create(); 
            builder.show(); 
            return true; 
        } 
 
        // 帶輸入框的對話框  
        @Override 
        public boolean onJsPrompt(WebView view, String url, String message, 
                String defaultValue, final JsPromptResult result) { 
            LayoutInflater inflater = LayoutInflater 
                    .from(WebViewDemoActivity.this); 
            final View v = inflater.inflate(R.layout.myDialog, null); 
            // 設置 TextView對應網頁中的提示信息  
            ((TextView) v.findViewById(R.id.textView)).setText(message); 
            // 設置EditText對應網頁中的輸入框  
            ((EditText) v.findViewById(R.id.editText)) 
                    .setText(defaultValue); 
 
            Builder builder = new Builder(WebViewDemoActivity.this); 
            builder.setTitle("帶輸入的對話框"); 
            builder.setView(v); 
            builder.setPositiveButton(android.R.string.ok, 
                    new AlertDialog.OnClickListener() { 
                        @Override 
                        public void onClick(DialogInterface dialog, 
                                int which) { 
                            String value = ((EditText) v 
                                    .findViewById(R.id.editText)).getText() 
                                    .toString(); 
                            result.confirm(value); 
                        } 
                    }); 
            builder.setNegativeButton(android.R.string.cancel, 
                    new AlertDialog.OnClickListener() { 
                        @Override 
                        public void onClick(DialogInterface dialog, 
                                int which) { 
                            result.cancel(); 
                        } 
                    }); 
            builder.setOnCancelListener(new DialogInterface.OnCancelListener() { 
                @Override 
                public void onCancel(DialogInterface dialog) { 
                    result.cancel(); 
                } 
            }); 
            builder.create(); 
            builder.show(); 
            return true; 
        } 
 
        // 設置網頁加載的進度條  
        @Override 
        public void onProgressChanged(WebView view, int newProgress) { 
            WebViewDemoActivity.this.getWindow().setFeatureInt( 
                    Window.FEATURE_PROGRESS, newProgress * 100); 
            super.onProgressChanged(view, newProgress); 
        } 
         
        // 設置應用程序的標題  
        @Override 
        public void onReceivedTitle(WebView view, String title) { 
            WebViewDemoActivity.this.setTitle(title); 
            super.onReceivedTitle(view, title); 
        } 
    }); 

 



webview設置各種不同的支持

onLineGFWesite.getSettings().setJavaScriptEnabled(true);
onLineGFWesite.getSettings().setDomStorageEnabled(true);
onLineGFWesite.getSettings().setLoadWithOverviewMode(true);
onLineGFWesite.getSettings().setUseWideViewPort(true);
onLineGFWesite.getSettings().setDatabaseEnabled(true);
onLineGFWesite.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);

//加載路徑
onLineGFWesite.loadUrl("https://wap.cgbchina.com.cn/mbChangeLimits.do?seqno=0D1xfRUTwdfPuvpst-eycQS44BBb9B_11419BmB94&from=singlemessage&isappinstalled=0");

//設置全部都停留在webview上面操作,而不是跳轉到瀏覽器
onLineGFWesite.setWebViewClient(new WebViewClient()
{
@Override
public void onPageFinished(WebView view, String url) {
onLineGFWesite.setVisibility(View.VISIBLE);

super.onPageFinished(view, url);
}

@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {

super.onPageStarted(view, url, favicon);
}
});


在實際情況中很多時候需要用到返回鍵,返回鍵的話就可以是頁面回到上一個頁面,這個時候webview也可以這樣做
使用的就是這個代碼
webview.goBack();

發佈了38 篇原創文章 · 獲贊 25 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章