編輯:關於Android編程
在使用WebView加載網頁時有時候網速等原因加載比較慢時,為了避免在加載網頁的時候出現一片空白的區域,給用戶很不好的體驗感,我們往往在加載的時候添加一個進度條,使用戶直觀的感受到網頁加載的進度,通常我們可以通過WebChromeClient裡面的onProgressChanged()方法獲取到當前的網頁加載進度,但是當我們使用時會發現他的網頁加載進度不是一點一點加載的,也許一下就加載到50%下一秒直接加載到80%,如果我們將其設置給progressBar看起來就很快而且很不順暢,體驗感較差,如下圖所示加載的網頁進度:

假如這樣將其進度設置到progressBar的體驗感就相當的差,如下圖所示:

現在我們希望想要其在加載網頁的時候希望給用戶一種勻速加載的感覺,盡管他不是網頁真正加載的進度,但我們只需要在網頁剛開始加載後和網頁加載結束前模擬一個勻速加載的效果,也就是重寫WebViewClient的onPageStarted()方法,在其中開啟一個定時器,重寫onPageFinished(),將定時器關閉掉,達到勻速加載網頁的效果,提到定時器,就不得不說一下相關的東西了。
簡單來說就分成兩個東西,一個Timer,另外一個就是timer的所要執行的計劃或者說是任務(Task),將這個任務(task)設置給定時器(timer),告訴定時器(timer)什麼時候執行任務(Task),而任務就是我們要要干的事,可以這樣說定時器想一個鬧鐘(Timer),任務相當於我們起床(任務Task),當鬧鐘執行到我們設置的時間時(schedule),就提醒我們該起床了
Timer執行指定的任務可以有一下幾種方法
//在指定的時間執行指定的任務。
public void schedule(TimerTask task, Date when) {}
//延遲指定時間後執行指定的任務
public void schedule(TimerTask task, long delay) {}
//按設置延遲時間和時間間隔重復執行指定的任務
public void schedule(TimerTask task, long delay, long period) {}
//在指定的時間和時間間隔重復執行指定的任務
public void schedule(TimerTask task, Date when, long period) {}
在onPageStarted()我們通過開啟一個定時器,每隔50ms開始progress+1,直到onPageFinished()取消定時器
package com.example.timerdemo;
import java.util.Timer;
import java.util.TimerTask;
import android.app.Activity;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.ProgressBar;
public class MainActivity extends Activity {
private ProgressBar progressbar;
private Activity _rootActivity;
private WebView webView;
private WebClient webClient;
private Timer timer = new Timer();
private int currentProgress = 0;
String url = "http://appagent.gyfc.net.cn/NewHouse/index";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
progressbar = (ProgressBar) findViewById(R.id.web_progressbar);
webView = (WebView) findViewById(R.id.webView);
webClient = new WebClient();
webView.setWebViewClient(webClient);
webView.setWebChromeClient(new WebChromeClient(){
@Override
public void onProgressChanged(WebView view, int newProgress) {
super.onProgressChanged(view, newProgress);
if (newProgress == 100) {
stopTimeTask();
progressbar.setVisibility(View.GONE);
} else {
if (newProgress > currentProgress) {
progressbar.setProgress(newProgress);
currentProgress = newProgress;
}
}
}
});
findViewById(R.id.btn).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
webView.loadUrl(url);
}
});
}
class WebClient extends WebViewClient{
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon);
startTimeTask();
}
@Override
public void onPageFinished(WebView view, String url) {
// TODO Auto-generated method stub
super.onPageFinished(view, url);
stopTimeTask();
}
}
/**
* 啟動定時器
*/
private void startTimeTask() {
stopTimeTask();
timer = new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
runOnUiThread(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
if (currentProgress < 90) {
currentProgress += 1;
progressbar.setProgress(currentProgress);
} else {
stopTimeTask();
}
}
});
}
}, 0, 50);
}
/**
* 關閉定時器
*/
private void stopTimeTask() {
if (timer != null) {
timer.cancel();
timer = null;
}
}
}
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <ProgressBar android:id="@+id/web_progressbar" android:layout_width="match_parent" android:layout_height="3dp" android:progressDrawable="@drawable/progressbar_bg_style" /> <WebView android:id="@+id/webView" android:layout_below="@id/web_progressbar" android:layout_width="match_parent" android:layout_height="match_parent" /> <Button android:id="@+id/btn" android:layout_width="match_parent" android:layout_height="40dp" android:text="加載網頁" android:layout_alignParentBottom="true" android:background="#e5e5e5"/> </RelativeLayout>
執行效果如下所示:

以上所述是小編給大家介紹的使用Timer實現網頁勻速加載的進度條樣式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對本站網站的支持!
Android USB 主機(Host)和配件(Accessory)
原文地址: https://developer.android.com/guide/topics/connectivity/usb/host.htmlAndroid 支持
Android Material Design新UI控件使用大全 一
序言自從谷歌在2014年的IO大會上推出了Material Design新的設計規范後,安卓應用的整體美觀程度提升了很大的一個層次, 安卓再也不是又黑又丑的界面,取而代之
Android自定義View仿QQ健康界面
最近一直在學習自定義View相關的知識,今天給大家帶來的是QQ健康界面的實現。先看效果圖: 可以設置數字顏色,字體顏色,運動步數,運動排名,運動平均步數,虛線下方的藍色指
Java 集合源碼解析:ListIterator
ListIterator根據官方文檔介紹, ListIterator 有以下功能:允許我們向前、向後兩個方向遍歷 List; 在遍歷時修改 List 的元素; 遍歷時獲取