使用Timer實現(xiàn)網(wǎng)頁勻速加載的進度條樣式
在使用WebView加載網(wǎng)頁時有時候網(wǎng)速等原因加載比較慢時,為了避免在加載網(wǎng)頁的時候出現(xiàn)一片空白的區(qū)域,給用戶很不好的體驗感,我們往往在加載的時候添加一個進度條,使用戶直觀的感受到網(wǎng)頁加載的進度,通常我們可以通過WebChromeClient里面的onProgressChanged()方法獲取到當前的網(wǎng)頁加載進度,但是當我們使用時會發(fā)現(xiàn)他的網(wǎng)頁加載進度不是一點一點加載的,也許一下就加載到50%下一秒直接加載到80%,如果我們將其設置給progressBar看起來就很快而且很不順暢,體驗感較差,如下圖所示加載的網(wǎng)頁進度:
假如這樣將其進度設置到progressBar的體驗感就相當?shù)牟?,如下圖所示:
現(xiàn)在我們希望想要其在加載網(wǎng)頁的時候希望給用戶一種勻速加載的感覺,盡管他不是網(wǎng)頁真正加載的進度,但我們只需要在網(wǎng)頁剛開始加載后和網(wǎng)頁加載結束前模擬一個勻速加載的效果,也就是重寫WebViewClient的onPageStarted()方法,在其中開啟一個定時器,重寫onPageFinished(),將定時器關閉掉,達到勻速加載網(wǎng)頁的效果,提到定時器,就不得不說一下相關的東西了。
簡單來說就分成兩個東西,一個Timer,另外一個就是timer的所要執(zhí)行的計劃或者說是任務(Task),將這個任務(task)設置給定時器(timer),告訴定時器(timer)什么時候執(zhí)行任務(Task),而任務就是我們要要干的事,可以這樣說定時器想一個鬧鐘(Timer),任務相當于我們起床(任務Task),當鬧鐘執(zhí)行到我們設置的時間時(schedule),就提醒我們該起床了
Timer執(zhí)行指定的任務可以有一下幾種方法
//在指定的時間執(zhí)行指定的任務。 public void schedule(TimerTask task, Date when) {} //延遲指定時間后執(zhí)行指定的任務 public void schedule(TimerTask task, long delay) {} //按設置延遲時間和時間間隔重復執(zhí)行指定的任務 public void schedule(TimerTask task, long delay, long period) {} //在指定的時間和時間間隔重復執(zhí)行指定的任務 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" style="?android:attr/progressBarStyleHorizontal" 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="加載網(wǎng)頁" android:layout_alignParentBottom="true" android:background="#e5e5e5"/> </RelativeLayout>
執(zhí)行效果如下所示:
以上所述是小編給大家介紹的使用Timer實現(xiàn)網(wǎng)頁勻速加載的進度條樣式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
Android使用Sqlite存儲數(shù)據(jù)用法示例
這篇文章主要介紹了Android使用Sqlite存儲數(shù)據(jù)的方法,結合實例形式分析了Android操作SQLite數(shù)據(jù)庫的相關步驟與操作技巧,需要的朋友可以參考下2016-11-11解決Android studio 2.3升級到Android studio 3.0 后apt報錯問題
原來項目在Android studio 2.3一切正常,升級到了3.0之后報錯,不支持apt了,其實解決這個問題很簡單,只需要修改兩點內(nèi)容就可以,下面腳本之家小編帶領大家通過本文學習吧2017-12-12Android啟動頁廣告(騰訊廣告聯(lián)盟)解決方法及源碼下載
這篇文章主要介紹了Android啟動頁廣告(騰訊廣告聯(lián)盟)解決方法的相關資料,啟動頁幾乎成為了每個app的標配,有些商家在啟動頁中增加了開屏廣告以此帶來更多的收入,需要的朋友可以參考下2017-03-03Android自定View實現(xiàn)滑動驗證效果的代碼
這篇文章主要介紹了Android自定View實現(xiàn)滑動驗證效果,代碼分為自定義屬性代碼和自定義view代碼及使用方法,本文給大家介紹的非常詳細,需要的朋友可以參考下2021-12-12Android?studio開發(fā)實現(xiàn)計算器功能
這篇文章主要為大家詳細介紹了Android?studio開發(fā)實現(xiàn)計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05Android使用ViewDragHelper實現(xiàn)圖片下拽返回示例
這篇文章主要介紹了Android使用ViewDragHelper實現(xiàn)圖片下拽返回示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08