WebView的使用及添加進度條

来源:http://www.cnblogs.com/wangfengdange/archive/2016/10/28/6008240.html
-Advertisement-
Play Games

實現的效果比較簡單類似於微信打開網頁,頭部有個進度條顯示載入進度 下載地址:http://download.csdn.net/detail/qq_29774291/9666941 1.在安卓端載入一個網頁 2.顯示網頁開始載入和載入的進度;不過在有時會出現onPageStarted等多次調用的情況, ...


實現的效果比較簡單類似於微信打開網頁,頭部有個進度條顯示載入進度

下載地址:http://download.csdn.net/detail/qq_29774291/9666941

1.在安卓端載入一個網頁

webView.loadUrl(urlString);

2.顯示網頁開始載入和載入的進度;不過在有時會出現onPageStarted等多次調用的情況,也許是網頁的問題,未找到處理方法

            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                // TODO Auto-generated method stub
                super.onPageStarted(view, url, favicon);
                System.out.println("Page開始  " + url  + "   " + favicon);
            }
            
            @Override
            public void onPageFinished(WebView view, String url) {
                // TODO Auto-generated method stub
                super.onPageFinished(view, url);
                System.out.println("Page結束  " +url);
            }
        webView.setWebChromeClient(new WebChromeClient(){
            @Override
            public void onProgressChanged(WebView view, int newProgress) {
                // TODO Auto-generated method stub
                super.onProgressChanged(view, newProgress);
                Log.d("jiejie", "ProgressChanged++  " + newProgress);
                if(newProgress ==100){
                    progressBar.setVisibility(View.GONE);
                    //progressBar.setProgress(newProgress);
                }else {
                    progressBar.setVisibility(View.VISIBLE);
                    progressBar.setProgress(newProgress);//設置載入進度
                }
            }
        });

3.重寫下ProgressBar的背景顏色progressDrawable需要使用layer-list來進行實現

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:id="@android:id/background">
        <shape>
            <corners android:radius="2dp" />
            <gradient
                android:angle="270"
                android:centerColor="#E3E3E3"
                android:endColor="#E6E6E6"
                android:startColor="#C8C8C8" />
        </shape>
    </item>
    <item android:id="@android:id/progress">
        <clip>
            <shape>
                <corners android:radius="2dp" />
                <gradient
                    android:centerColor="#4AEA2F"
                    android:endColor="#31CE15"
                    android:startColor="#5FEC46" />
                
            </shape>
        </clip>
    </item>

</layer-list>
View Code

4.WebSettings 的常用方法介紹

setJavaScriptEnabled(true);  //支持js

setPluginsEnabled(true);  //支持插件 

setUseWideViewPort(false);  //將圖片調整到適合webview的大小 

setSupportZoom(true);  //支持縮放 

setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持內容重新佈局  

supportMultipleWindows();  //多視窗 

setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);  //關閉webview中緩存 

setAllowFileAccess(true);  //設置可以訪問文件 

setNeedInitialFocus(true); //當webview調用requestFocus時為webview設置節點

webview webSettings.setBuiltInZoomControls(true); //設置支持縮放 

setJavaScriptCanOpenWindowsAutomatically(true); //支持通過JS打開新視窗 

setLoadWithOverviewMode(true); // 縮放至屏幕的大小

setLoadsImagesAutomatically(true);  //支持自動載入圖片

5.WebViewClient 的方法全解

doUpdateVisitedHistory(WebView view, String url, boolean isReload)  //(更新曆史記錄) 

onFormResubmission(WebView view, Message dontResend, Message resend) //(應用程式重新請求網頁數據) 

onLoadResource(WebView view, String url) // 在載入頁面資源時會調用,每一個資源(比如圖片)的載入都會調用一次。 

onPageStarted(WebView view, String url, Bitmap favicon) //這個事件就是開始載入頁面調用的,通常我們可以在這設定一個loading的頁面,告訴用戶程式在等待網路響應。 

onPageFinished(WebView view, String url) //在頁面載入結束時調用。同樣道理,我們知道一個頁面載入完成,於是我們可以關閉loading 條,切換程式動作。 

onReceivedError(WebView view, int errorCode, String description, String failingUrl)// (報告錯誤信息) 

onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host,String realm)//(獲取返回信息授權請求) 
 
onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) //重寫此方法可以讓webview處理https請求。
 
onScaleChanged(WebView view, float oldScale, float newScale) // (WebView發生改變時調用) 

onUnhandledKeyEvent(WebView view, KeyEvent event) //(Key事件未被載入時調用) 

shouldOverrideKeyEvent(WebView view, KeyEvent event)//重寫此方法才能夠處理在瀏覽器中的按鍵事件。 

shouldOverrideUrlLoading(WebView view, String url) 
//在點擊請求的是鏈接是才會調用,重寫此方法返回true表明點擊網頁裡面的鏈接還是在當前的webview里跳轉,不跳到瀏覽器那邊。這個函數我們可以做很多操作,比如我們讀取到某些特殊的URL,於是就可以不打開地址,取消這個操作,進行預先定義的其他操作,這對一個程式是非常必要的。

6.主程式代碼

  1 package com.item.jiejie.activity;
  2 
  3 import com.item.jiejie.R;
  4 
  5 import android.annotation.SuppressLint;
  6 import android.app.Activity;
  7 import android.graphics.Bitmap;
  8 import android.os.Bundle;
  9 import android.util.Log;
 10 import android.view.KeyEvent;
 11 import android.view.View;
 12 import android.webkit.WebChromeClient;
 13 import android.webkit.WebSettings;
 14 import android.webkit.WebView;
 15 import android.webkit.WebViewClient;
 16 import android.widget.ProgressBar;
 17 
 18 /**
 19  * 實現加在一個WebView 為WebView載入時添加一個類型微信的進度條
 20  * @author Administrator
 21  *
 22  */
 23 @SuppressLint("SetJavaScriptEnabled")
 24 public class WebViewActivity extends Activity{
 25     private WebView webView;
 26     private ProgressBar progressBar;
 27     private String urlString = "http://61.156.45.47:8081/dtmsapp/sy.html";
 28     @Override
 29     protected void onCreate(Bundle savedInstanceState) {
 30         // TODO Auto-generated method stub
 31         super.onCreate(savedInstanceState);
 32         setContentView(R.layout.actvity_webview);
 33         initView();
 34     }
 35     private void initView() {
 36         // TODO Auto-generated method stub
 37         webView = (WebView)findViewById(R.id.webview);
 38         progressBar = (ProgressBar)findViewById(R.id.pergress);
 39         WebSettings webSettings = webView.getSettings();
 40         webSettings.setJavaScriptEnabled(true);
 41         webSettings.setUseWideViewPort(true);
 42         webSettings.setLoadWithOverviewMode(true);
 43         webSettings.setDefaultTextEncodingName("utf-8");
 44         webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);//關閉WebView中緩存
 45         webView.setWebViewClient(new WebViewClient(){
 46             @Override
 47             public void onPageStarted(WebView view, String url, Bitmap favicon) {
 48                 // TODO Auto-generated method stub
 49                 super.onPageStarted(view, url, favicon);
 50                 System.out.println("Page開始  " + url  + "   " + favicon);
 51             }
 52             
 53             @Override
 54             public void onPageFinished(WebView view, String url) {
 55                 // TODO Auto-generated method stub
 56                 super.onPageFinished(view, url);
 57                 System.out.println("Page結束  " +url);
 58             }
 59             @Override
 60             public boolean shouldOverrideUrlLoading(WebView view, String url) {
 61                 // TODO Auto-generated method stub
 62                 //return super.shouldOverrideUrlLoading(view, url);
 63                 view.loadUrl(url);
 64                 return true;
 65             }
 66         });
 67         webView.setWebChromeClient(new WebChromeClient(){
 68             @Override
 69             public void onProgressChanged(WebView view, int newProgress) {
 70                 // TODO Auto-generated method stub
 71                 super.onProgressChanged(view, newProgress);
 72                 Log.d("jiejie", "ProgressChanged++  " + newProgress);
 73                 if(newProgress ==100){
 74                     progressBar.setVisibility(View.GONE);
 75                     //progressBar.setProgress(newProgress);
 76                 }else {
 77                     progressBar.setVisibility(View.VISIBLE);
 78                     progressBar.setProgress(newProgress);//設置載入進度
 79                 }
 80             }
 81         });
 82         webView.loadUrl(urlString);
 83     }
 84     
 85     //設置返回鍵動作(防止按返回鍵直接退出程式)
 86         @Override
 87         public boolean onKeyDown(int keyCode, KeyEvent event) {
 88             // TODO 自動生成的方法存根
 89             if(keyCode==KeyEvent.KEYCODE_BACK) {
 90                 if(webView.canGoBack()) {//當webview不是處於第一頁面時,返回上一個頁面
 91                     webView.goBack();
 92                     return true;
 93                 }
 94 //                else {//當webview處於第一頁面時,直接退出程式
 95 //                    System.exit(0);
 96 //                }
 97                 
 98             
 99             }
100             return super.onKeyDown(keyCode, event);
101         }
102 }

 

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 啦啦啦~本學期要開始學習Android開發啦~ 博主在開始學習前是完完全全的小白,只有在平時完成老師要求的實驗的過程中一步一步學習~從此篇博文起,博主將開始發佈Android開發有關的博文,希望能在學習中和各位共同探討,一起交流,共同進步~ 話不多說,首先進入我們的正題~Android開發一基 ...
  • 創建博客有一年的時間了,一直沒把它用起來,頗感慚愧。近日突感有寫博客的衝動,更可怕的是這種衝動似乎比我體內的洪荒之力更為凶猛。於是乎,這篇博客悄然誕生。廢話不多說,進入正題——初識Android。 這篇博客從最基本的知識講起 .. LinearLayout 特有代碼: android:orienta ...
  • 打電話應用 system/app/phone.apk 這個是打電話應用,這個Java API 不允許應用級程式員改寫,系統級才可以 system/app/dialer.apk 這個是撥號器應用,可以重寫一個第三方的撥號器 1.在res-layout-activity_main.xml里定義佈局: 2 ...
  • 首先一個android項目,然後編譯和打包,將.java文件編譯為.class,.class編譯為.dex,將所有文件打包為一個apk,只編譯代碼,不編譯資源。 .apk裡面的.arsc是資源的索引,當資源比較多的時候,可以索引。 signing-簽名,系統在確認應用被覆蓋之前,除了檢測包名是否一致 ...
  • button的點擊效果無疑是非常簡單的,以致於我懶到當UI告訴我說在點擊的時候button字體的顏色也要隨著背景改變的時候我毫不猶豫的告訴他讓他切兩個圖過來,後來想想著實是不太靠譜,於是瞭解了一下如何添加button點擊的字體顏色變化效果。 1.首先你要在你的color文件下加入幾個你需要的色值,註 ...
  • 1:iOS項目配置文件info.plist文件解析 2:iOS最新的許可權設置 3:關於openURL 蘋果在iOS 2中引入了openURL:方法來進行APP間的跳轉。不過在iOS 9中,相關的canOpenURL在iOS 10中,蘋果已棄用了openURL,轉而用openURL:options:c ...
  • MenuPopwindow: 1 package com.cloudeye.android.cloudeye.view; 2 3 import android.app.Activity; 4 import android.content.Context; 5 import android.graph ...
  • Android Studio常用快捷鍵 Android Studio日常開發常用快捷鍵. 快捷鍵版本: Mac OS X 10.5+ 搜索查看類 | 用途 | Mac快捷鍵 | |: |: | | 搜索所有文件 | double Shift | | 搜索文件 | Cmd + Shift + O | ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...