Android WebView 进度回调至 70%停止

和别的项目不太一样的是,出现这个问题是因为打印需要实时加载webview的内容,在activity是上没有webview这个控件的,所以没有用第三方的浏览器加载。

现象是低于安卓12版本或以上,加载第一次的时候地址A打开成功,生成一条新数据得到地址B的时候,点击打印,理想流程是,webview加载完onProgressChanged方法Progress==100时通过getSystemService(Context.PRINT_SERVICE)去调用打印。骨感现实是,onProgressChanged到70%死活不动了。

然后kill APP,再次进入地址B又能打开了。和Android webview只加载10%且出现白屏问题排查解决_webview白屏加载不出来_不二菜菜子的博客-CSDN博客

这个老哥很像。我也经历了删缓存之路,没用哈哈哈哈哈。

但是我的是加载一直卡在70%,通过打印onLoadResource查看加载资源卡在哪一步,发现是资源都加载了,只有最后H5请求后台的接口没有发出去,和前端沟通,看下他的H5代码,顺便改了H5的加载流程

按照最后老哥最后提供的解决方法,在activity初始化里的时候初始化webview并添加

printWebView.onResume();

加上自己的webview初始化时设置webSetting,设置不要缓存。

WebSettings webSetting = printWebView.getSettings(); webSetting.setCacheMode(WebSettings.LOAD_NO_CACHE); webSetting.setJavaScriptEnabled(true);
// 允许从任何来源加载内容,即使起源是不安全的; //webview 从Lollipop(5.0)开始 webview默认不允许混合模式,https当中不能加载http资源,如果要加载,需单独设置开启

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { webSetting.setMixedContentMode(android.webkit.WebSettings.MIXED_CONTENT_ALWAYS_ALLOW); }

complete = false;
printWebView.setWebChromeClient(new WebChromeClient() {
    @Override
    public void onProgressChanged(WebView view, int newProgress) {
        LogUtils.i("加载进度:onProgressChanged>>>>" + newProgress);
        //这也是个坑,在某些机型上100会发2次!!!
        if (newProgress == 100 && !complete){
            complete = true;
            printOrCreatePdfFromWebview(view,                 getString(R.string.detection_datail_title));
        }
        super.onProgressChanged(view, newProgress);
    }
});

然后再

@Override
protected void onDestroy() {
    super.onDestroy();
    if (printWebView != null) {
        printWebView.resumeTimers();
        printWebView.destroy();
        printWebView = null;
    }
}

问题解决!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 中,可以通过 WebViewClient 来监听 WebView 的加载事件。具体来说,可以通过重写 WebViewClient 的 onPageFinished 方法来实现 WebView 加载成功的回调,示例代码如下: ``` webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { // WebView 加载成功的回调 } }); ``` 在 onPageFinished 方法中,第一个参数 view 表示当前 WebView 对象,第二个参数 url 则表示当前 WebView 加载的页面 URL。你可以在方法中添加相应的逻辑来处理 WebView 加载成功后的事件。 除了 onPageFinished 方法,WebViewClient 还提供了其他的一些监听方法,常用的包括: - onPageStarted:WebView 开始加载时的回调。 - onReceivedError:WebView 加载出错时的回调。 - onReceivedSslError:WebView 加载 HTTPS 页面出错时的回调。 你可以根据实际需求重写这些方法,并添加相应的逻辑来实现自己的业务逻辑。具体示例代码如下: ``` webView.setWebViewClient(new WebViewClient() { @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { // WebView 开始加载的回调 } @Override public void onPageFinished(WebView view, String url) { // WebView 加载成功的回调 } @Override public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { // WebView 加载出错的回调 } @Override public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) { // WebView 加载 HTTPS 页面出错的回调 } }); ``` 需要注意的是,如果你需要在 WebView 中加载 HTTPS 页面,可能会遇到证书验证问题。如果你的证书无法通过验证,可以通过重写 onReceivedSslError 方法来处理这个问题,具体实现方式可以参考相关文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值