WebView加载进度Progress的显示

最近项目中用到WebView来显示网页,  一般浏览器加载网页都会显示进度,所以想在使用WebView时也能显示加载进度,现在尝试几种实现方法 ~~


一。利用Window的进度条

        该种方法显示的进度条属于Activity的,即在Activity的标题栏与状态栏之间那进度条,显然,Activity必须要有TitleBar。

       然后,为Activity设置进度条属性如下Feature:

         getWindow().requestFeature(Window.FEATURE_PROGRESS);

       最后,调用setProgress(int progress)来设置进度条的进度。

        具体的代码如下:

package com.Hunman.mywebview;

import android.app.Activity;
import android.os.Bundle;
import android.os.Message;
import android.view.Window;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;

public class MainActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
//		setContentView(R.layout.activity_main);
		
		this.getWindow().requestFeature(Window.FEATURE_PROGRESS);
		LinearLayout layout = new LinearLayout(this);
		LayoutParams params = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
		
		WebView webView = new WebView(this);
		webView.getSettings().setJavaScriptEnabled(true);
		webView.getSettings().setSupportZoom(true);
		webView.requestFocus();
		webView.setWebChromeClient(mWebChromeClient);
		webView.loadUrl("http://site.baidu.com/");		
		layout.addView(webView, params);
		
		setContentView(layout);
	}
	
	private WebChromeClient mWebChromeClient = new WebChromeClient() {

		@Override
		public void onProgressChanged(WebView view, int newProgress) {
            setProgress(newProgress*100);
            super.onProgressChanged(view, newProgress);
		}

		@Override
		public void onReceivedTitle(WebView view, String title) {
			// TODO Auto-generated method stub
			super.onReceivedTitle(view, title);
		}

		@Override
		public void onReceivedTouchIconUrl(WebView view, String url,
				boolean precomposed) {
			// TODO Auto-generated method stub
			super.onReceivedTouchIconUrl(view, url, precomposed);
		}

		@Override
		public boolean onCreateWindow(WebView view, boolean isDialog,
				boolean isUserGesture, Message resultMsg) {
			// TODO Auto-generated method stub
			return super.onCreateWindow(view, isDialog, isUserGesture, resultMsg);
		}
		
	};

}



二。 重写WebView中添加进度条

         首先,重写webView控件,重写控件的方法不多说,网上一堆堆;

         然后,在WebView中添加Progress控件,也很简单:

mProgressbar = new ProgressBar(context, null, android.R.attr.progressBarStyleHorizontal);
mProgressbar.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT, 10, 0, 0));
addView(mProgressbar);

        再然后,在WebChromeClient中设置进度的改变;

        最后,还要在onScrollChanged()中设置Progress位置,否则WebView向下滚动网页,进度条也会滚动隐藏,不适合用户体验。

         下面直接看WebView重写后的代码:

package com.Hunman.mywebview;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.Context;
import android.os.Message;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.ProgressBar;

public class AdsWebView extends WebView {
	private static final String TAG = "wxx";
	private String mUrl;
	ProgressBar mProgressbar;
	
	public AdsWebView(Context context, String url) {
		super(context);
		this.mUrl = url;
		init(context);
	}

	
	@SuppressLint({ "SetJavaScriptEnabled", "NewApi" })
	private void init(Context context) {
		//添加进度 条
		mProgressbar = new ProgressBar(context, null, android.R.attr.progressBarStyleHorizontal);
		mProgressbar.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT, 10, 0, 0));
		addView(mProgressbar);
		
		WebSettings webSettings = this.getSettings();
		webSettings.setJavaScriptEnabled(true);
		webSettings.setSupportZoom(true);
		//webSettings.setUseWideViewPort(true);
		this.requestFocus();
		this.setWebChromeClient(mWebChromeClient);
		this.loadUrl(mUrl);
		this.onResume();
	}
	
	private WebChromeClient mWebChromeClient = new WebChromeClient() {

		@Override
		public void onProgressChanged(WebView view, int newProgress) {
            if (newProgress == 100) {
            	mProgressbar.setVisibility(GONE);
            } else {
                if (mProgressbar.getVisibility() == GONE)
                	mProgressbar.setVisibility(VISIBLE);
                mProgressbar.setProgress(newProgress);
            }
            super.onProgressChanged(view, newProgress);
		}

		@Override
		public void onReceivedTitle(WebView view, String title) {
			// TODO Auto-generated method stub
			super.onReceivedTitle(view, title);
		}

		@Override
		public void onReceivedTouchIconUrl(WebView view, String url,
				boolean precomposed) {
			// TODO Auto-generated method stub
			super.onReceivedTouchIconUrl(view, url, precomposed);
		}

		@Override
		public boolean onCreateWindow(WebView view, boolean isDialog,
				boolean isUserGesture, Message resultMsg) {
			// TODO Auto-generated method stub
			return super.onCreateWindow(view, isDialog, isUserGesture, resultMsg);
		}
		
	};

	//保证向下流动webView时,Progress正常显示,而非隐藏
	@Override
	protected void onScrollChanged(int l, int t, int oldl, int oldt) {
		// TODO Auto-generated method stub
        LayoutParams lp = (LayoutParams) mProgressbar.getLayoutParams();
        lp.x = l;
        lp.y = t;
        mProgressbar.setLayoutParams(lp);
        super.onScrollChanged(l, t, oldl, oldt);
	}

}


三。其他方法

        比如,把progress和webview在xml文件中布局,再重写Webview;

        又如,弹出Dialog显示进度条,等 等 方法。这些方法自己尝试实现吧。。


        下篇博客,会对WebView的使用实现进行全面讲解。欢迎参考。

你可能感兴趣的:(android,webView,progress)