Android 实现带进度条的WebView的实例

 更新时间:2017年07月28日 09:29:53   投稿:lqh  
这篇文章主要介绍了Android 实现带进度条的WebView的实例的相关资料,这里介绍了Webview加载网页的方法及带进度的Drawable文件view_progress_webview的实现,需要的朋友可以参考下

Android 实现带进度条的WebView的实例

1. WebView加载网页方法

//加载本地资源
loadUrl("file:///android_asset/example.html");
//加载网络资源
loadUrl("http://baidu.com");

2. 带进度的Drawable文件view_progress_webview

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

  <item android:id="@android:id/progress">
    <clip>
      <shape>
        <solid android:color="#31CE15"/>
        <corners android:radius="2dp"/>
      </shape>
    </clip>
  </item>

</layer-list>

颜色值为进度颜色,根据需要更换

3. ProgressWebView类

/**
 * 带进度条的WebView
 * @Author GQ
 */
public class ProgressWebView extends WebView {

  private ProgressBar progressbar;
  private Context mContext;

  public ProgressWebView(Context context, AttributeSet attrs) {
    super(context, attrs);
    this.mContext = context;
    progressbar = new ProgressBar(context, null, android.R.attr.progressBarStyleHorizontal);
    progressbar.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, 5, 0, 0));

    Drawable drawable = context.getResources().getDrawable(R.drawable.view_progress_webview);
    progressbar.setProgressDrawable(drawable);
    addView(progressbar);

    //主要处理解析,渲染网页等浏览器做的事情
    setWebViewClient(new WebViewClient() {
      @Override
      public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
        super.onReceivedError(view, errorCode, description, failingUrl);
        //加载失败时候,显示自定义的页面
        if (errorListener != null) {
          errorListener.onError();
        }
      }
    });
    //辅助WebView处理Javascript的对话框,网站图标,网站title,加载进度等
    setWebChromeClient(new WebChromeClient());

    getSettings().setSupportZoom(true);//是否可以缩放
    getSettings().setBuiltInZoomControls(true);
    getSettings().setJavaScriptEnabled(true);//支持JS
    getSettings().setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);
    getSettings().setUseWideViewPort(true);
    getSettings().setLoadWithOverviewMode(true);
    getSettings().setSaveFormData(true);
    getSettings().setDomStorageEnabled(true);

    //优先使用缓存
    getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);

    //禁用长按
    setOnLongClickListener(new OnLongClickListener() {
      @Override
      public boolean onLongClick(View view) {
        return true;
      }
    });

    //如果在浏览器下载,调用浏览器默认下载+通知栏
    setDownloadListener(new DownloadListener() {
      @Override
      public void onDownloadStart(String url, String userAgent, String contentDisposition, String mimetype, long contentLength) {
        Uri uri = Uri.parse(url);
        Intent intent = new Intent(Intent.ACTION_VIEW, uri);
        mContext.startActivity(intent);
      }
    });
  }


  public class WebChromeClient extends android.webkit.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);
    }

    @Override
    public void onReceivedTitle(WebView view, String title) {
      super.onReceivedTitle(view, title);
      if (titleListener != null)
        titleListener.getTitle(title);
    }

  }


  @Override
  protected void onScrollChanged(int l, int t, int oldl, int oldt) {
    LayoutParams lp = (LayoutParams) progressbar.getLayoutParams();
    lp.x = l;
    lp.y = t;
    progressbar.setLayoutParams(lp);
    super.onScrollChanged(l, t, oldl, oldt);
  }

  private TitleListener titleListener;

  public interface TitleListener {
    void getTitle(String title);
  }

  public void setOnTitleListener(TitleListener titleListener) {
    this.titleListener = titleListener;
  }

  private ErrorListener errorListener;

  public interface ErrorListener {
    void onError();
  }

  public void setOnErrorListener(ErrorListener errorListener) {
    this.errorListener = errorListener;
  }

}

4. 使用

/**
* 公共WebView
*/
public class BasicWebActivity extends Activity {

  protected ProgressWebView progressWebView;
  private TextView title;//标题栏
  private TextView tv_none;//加载失败显示文字

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.common_webview);

    title = (TextView) findViewById(R.id.title);
    tv_none = (TextView) findViewById(R.id.tv_none);
    progressWebView = (ProgressWebView) findViewById(R.id.progressWebView);

    String url = getIntent().getStringExtra("url");
    progressWebView.setOnTitleListener(new ProgressWebView.TitleListener() {
      @Override
      public void getTitle(String title) {
        title.setText(title);
      }
    });
    progressWebView.setOnErrorListener(new ProgressWebView.ErrorListener() {
      @Override
      public void onError() {
        tv_none.setText("url资源失效");
      }
    });
    //加载网页
    progressWebView.loadUrl(url);
  }

 //重写返回键
  @Override
  public boolean onKeyDown(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_BACK) {
      if (progressWebView.canGoBack()) {
        progressWebView.goBack();//返回上一层页面
        return true;
      } else {
        finish();//关闭页面
      }
    }
    return super.onKeyDown(keyCode, event);
  }
}

其中common_webview就包含一个title一个progressWebView就不贴代码了。

如有疑问,请留言或者到本站社区交流讨论,本站关于Android开发的文章还有很多,还希望大家搜索参阅,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Android日志文件的读写工具类

    Android日志文件的读写工具类

    这篇文章主要为大家详细介绍了Android日志文件的读写工具类,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • Kotlin标准函数与静态方法应用详解

    Kotlin标准函数与静态方法应用详解

    Kotlin中的标准函数指的是Standard.kt文件中定义的函数,任何Kotlin代码都可以自由地调用所有的标准函数。例如let这个标准函数,他的主要作用就是配合?.操作符来进行辅助判空处理
    2022-12-12
  • Android RecyclerView实现悬浮吸顶、分隔线、到底提示效果

    Android RecyclerView实现悬浮吸顶、分隔线、到底提示效果

    这篇文章主要介绍了Android RecyclerView实现悬浮吸顶、分隔线、到底提示效果,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • Android通过自定义View实现随机验证码

    Android通过自定义View实现随机验证码

    这篇文章主要介绍了Android通过自定义View实现随机验证码的相关资料,需要的朋友可以参考下
    2016-03-03
  • Android存储卡读写文件与Application数据保存的实现介绍

    Android存储卡读写文件与Application数据保存的实现介绍

    这篇文章主要介绍了Android在存储卡上读写文件、Application保存数据的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-09-09
  • 安卓逆向腾讯动漫app返回数据加密分析案例分享

    安卓逆向腾讯动漫app返回数据加密分析案例分享

    这篇文章主要为大家介绍了安卓逆向腾讯动漫app返回数据加密分析的案例分享,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-02-02
  • 详解Android Studio3.5及使用AndroidX的一些坑

    详解Android Studio3.5及使用AndroidX的一些坑

    这篇文章主要介绍了详解Android Studio3.5及使用AndroidX的一些坑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • android自定义环形对比图效果

    android自定义环形对比图效果

    这篇文章主要为大家详细介绍了android自定义环形对比图,外环有类似进度条的旋转动画,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10
  • Android实现设置APP灰白模式效果

    Android实现设置APP灰白模式效果

    大家好,本篇文章主要讲的是Android实现设置APP灰白模式效果,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • Android开发实现NFC刷卡读取的两种方式

    Android开发实现NFC刷卡读取的两种方式

    这篇文章主要为大家详细介绍了Android开发中实现NFC刷卡读取的两种方式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09

最新评论