Webview获取html网络图片

本文介绍了使用Webview获取网页标题、长按图片URL及所有图片URL的方法,并探讨了Webview缓存机制。通过示例代码展示了如何设置监听器来捕获这些信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

一些需求确实比较变态,官网上api 方法太多,看的朦朦胧胧,是懂非懂,加下强大的搜索引擎,不难找不到解决的方法。

获取网页title
 mWebView.setWebChromeClient(new WebChromeClient() {
            @Override
            public void onReceivedTitle(WebView view, String title) {
                super.onReceivedTitle(view, title);
                if (!TextUtils.isEmpty(title)) {

                    Log.e(TAG, "onReceivedTitle:title  " +title );
                }

            }
 }
获取长按处图片url
 mWebView.setOnLongClickListener(new View.OnLongClickListener() {
            @Override
            public boolean onLongClick(View v) {
               // webview长按后,通过getHitTestResult()方法可以得到一个HitTestResult对象,通过这个对象可以知道点击区域的内容是什么mimeType以及对应的url。
                WebView.HitTestResult result = mWebView.getHitTestResult();
                if (result.getType() == WebView.HitTestResult.IMAGE_TYPE) {
                    String url = result.getExtra();
                    Log.e(TAG, "onLongClick:长按处图片  url " + url );
                    return true;
                }
                return false;
            }
        });
获取网页所有图片url
 mWebView.setWebViewClient(new WebViewClient() {
            @Override
            public WebResourceResponse shouldInterceptRequest(WebView view,                                                   String url) {
                Log.e(TAG, "shouldInterceptRequest: " + url  );

                    }
                }
                return null;
            }

            //第二个方法是v21才有的,用于替代第一个方法
            @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
            @Override
            public WebResourceResponse shouldInterceptRequest(WebView view,                                                         WebResourceRequest request) {
                Log.e(TAG, "shouldInterceptRequest: 替代  " + request.getUrl() );
                String imgUrl = request.getUrl().toString();
                if(imgUrl.endsWith(".png") || imgUrl.endsWith(".jpg") ){

                    iconList.add(imgUrl);
                }
                return super.shouldInterceptRequest(view, request);
            }
        });
了解Webview 的缓存

参考:
从WebView获取图片的几种方式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值