編輯:關於android開發
實現的效果比較簡單類似於微信打開網頁,頭部有個進度條顯示加載進度
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 }
Android 下拉列表框、文本框、菜單,android列表框
Android 下拉列表框、文本框、菜單,android列表框1、下拉列表框(Spinner) 項目布局 <RelativeLayout xmlns:androi
Adapter,adapter是什麼意思
Adapter,adapter是什麼意思Adapter是連接後端數據和前端顯示的適配器接口,是數據和UI之間的一個重要的紐帶。在常見的View等地方都需要用到Adapte
Android特效專輯(六)——仿QQ聊天撒花特效,無形裝逼,最為致命
Android特效專輯(六)——仿QQ聊天撒花特效,無形裝逼,最為致命 Android特效專輯(六)——仿QQ聊天撒花特效,無形裝逼,最為致命
Android客戶端性能優化(魅族資深工程師毫無保留奉獻)
Android客戶端性能優化(魅族資深工程師毫無保留奉獻) 本文由魅族科技有限公司資深Android開發工程師degao(嵌入式企鵝圈原創團隊成員)撰寫,是degao