Android如何实现自定义带进度条WebView仿微信加载-创新互联

这篇文章主要介绍Android如何实现自定义带进度条WebView仿微信加载,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

创新互联建站于2013年开始,先为雁塔等服务建站,雁塔等地企业,进行企业商务咨询服务。为雁塔企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

本文结构:

1、自定义webView
2、在应用中的使用
3、效果展示

一、自定义webView

1、首先定义一个类,继承webView,并首先构造方法

public class ProgressBarWebView extends WebView{}

自定义控件,先实现构造方法,
第一中是程序内部实例化采用,传入context

public ProgressBarWebView(Context context) {
 super(context);
 }

第二种用于layout实例化,会把xml的参数通过AttributeSet带入View内

public ProgressBarWebView(Context context, AttributeSet attrs) {
 super(context, attrs);
 }

第三种主题的style信息,也从XML带入

public ProgressBarWebView(Context context, AttributeSet attrs,
  int defStyleAttr) {
 super(context, attrs, defStyleAttr);
 }

而我们需要加载进度条布局,所以我们需要在第二中构造方法中进行操作,如下:

//选创建一个进度条,我们这里创建的是一个横向的进度条
progressBar = new ProgressBar(context, null, android.R.attr.progressBarStyleHorizontal); 
//设置该进度条的位置参数
progressBar.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, 10, 0, 0)); 
//我们想要设置该进度条的背景样式 
Drawable drawable = context.getResources().getDrawable(R.drawable.progress_bar_states);
//设置背景样式 
progressBar.setProgressDrawable(drawable); 
//调用本身的addView(其实是调用ViewManager里的方法,看源码)方法讲进度条添加到当前布局视图中
addView(progressBar); 
//正常想获取或这进行交互一般要实现一下两个方法,Myweblient()可以限制不用手机本身的浏览器,MyChromeClient()可以获得网页加载的进度,title等
setWebViewClient(new Myweblient()); 
setWebChromeClient(new MyChromeClient()); 
//是否可以缩放 
getSettings().setSupportZoom(true); 
getSettings().setBuiltInZoomControls(true);

2、重写WebViewClient,设置再本身的webview打开,不调用系统的浏览器:

//需要自己设置要不会打开手机浏览器
 private class Myweblient extends WebViewClient{
 @Override
 public boolean shouldOverrideUrlLoading(WebView view, String url) {
  view.loadUrl(url);
  return true;
 }
 }

3、重写WebChromeClient,获取相应进度信息,并设置

private class MyChromeClient extends WebChromeClient{
 @Override 
 public void onProgressChanged(WebView view, int newProgress) { 
  if (newProgress == 100) { //当网页全部加载完毕时
  progressBar.setVisibility(GONE); 
  } else { 
  if (progressBar.getVisibility() == GONE) 
   progressBar.setVisibility(VISIBLE); 
  progressBar.setProgress(newProgress); 
  } 
  super.onProgressChanged(view, newProgress); 
 } 

 }

4、前文构造器我们提到的进度条背景R.drawable.progress_bar_states,需要再xml中定义;



 
  
  
   

   
  
  
 
  
  
   
   

   
   
  
 

二、在页面中的使用

//布局中

Activity中使用

ProgressBarWebView webView=(ProgressBarWebView) findViewById(R.id.ss);
webView.loadUrl("http://www.baidu.com/");

三、最终效果

Android如何实现自定义带进度条WebView仿微信加载

Android如何实现自定义带进度条WebView仿微信加载

以上是“Android如何实现自定义带进度条WebView仿微信加载”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!


标题名称:Android如何实现自定义带进度条WebView仿微信加载-创新互联
分享URL:http://cdiso.cn/article/hicih.html

其他资讯