android webView 图片选择

android webView 图片选择

一、webView 图片选择器调用触发

开发中经常会与H5 交互,遇到图片选择怎么办呢?

WebChromeClient 中 onShowFileChooser 可以用来处理图片选择问题

代码如下:

  mWebView.setWebChromeClient(new WebChromeClient(){
            private Uri imgUri;
            @Override
            public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {
                return true; //todo  ture 处理数据
            }

        });

onShowFileChooser:对应了html 表单中 中 input 标签中的type= file 类型,在pc 端会触发 一个文件资源管理器,

在webView 中 则会触发 WebChromeClient 中 onShowFileChooser 方法,在该方法中我们可以调用相册选择器或者自定义的照片选择器控件

onShowFileChooser参数:

  • WebView :webView 组件

  • ValueCallback<Uri[]>

    接收选择照片后uri 数组,在选择成功之后,调用 :

    filePathCallback.onReceiveValue(uris);
    
  • FileChooserParams

    系统图片选择器打开所配置的参数

onShowFileChooser 返回值:

onShowFileChooser 返回值为一个boolean 类型 true/false,默认值是false

二、图片选择回调处理

onShowFileChooser 调用图片选择器之后 必须修改默认返回值为true ,方能正确处理数据

filePathCallback 接口参数处理 :

 uris = new Uri[photos.size()];
	....
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {   //N android 7.0
    	  imgUri = FileProvider.getUriForFile(mRootView.getActivity(),	mRootView.getActivity().getPackageName() + ".fileProvider", new File(photos.get(i).getCompressionPath()));
    }
	uris[i] = imgUri;

  filePathCallback.onReceiveValue(uris);
return true;

处理图片选择取消回调

调用图片选择器取消之后 filePathCallback 必须传入一个null 参数 代码:

通常会在 onActivityResult 方法中处理

  @Override
    protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
    	if(success){
            photos //图片数据
        }else{
            filePathCallback.onReceiveValue(null);
 		   filePathCallback = null;
        }
    }

三、常见问题(Exception)

showFileChooser result was already called

onShowFileChooser 返回值为 false 导致 修改为 true

java.lang.IllegalStateException: Duplicate showFileChooser result

filePathCallback.onReceiveValue() 方法连续调用两次所致

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android WebView中实现图片点击事件,主要通过以下步骤: 1. 首先,需要注入JavaScript代码到WebView中,以便响应图片的点击事件。可以使用WebView的addJavascriptInterface()方法将一个Java对象注入到WebView中,这个Java对象可以作为JavaScript对象在WebView中调用。 2. 创建一个自定义的Java类,例如ImageJavascriptInterface,该类包含一个openImage()方法,用于处理图片点击事件。在openImage()方法中,可以执行跳转到图片查看页面等操作。 3. 在WebViewWebViewClient中的onPageFinished()方法中,通过执行JavaScript代码,为每个图片添加点击事件监听器,并调用注入的Java对象的openImage()方法。这样当用户点击图片时,会触发openImage()方法,并传递图片的URL和位置信息。 4. 最后,将HTML数据加载到WebView中,可以使用loadData()方法。 综上所述,通过注入JavaScript代码和自定义的Java对象,可以实现在Android WebView中响应图片点击事件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [android webview js交互, 响应webview中的图片点击事件](https://download.csdn.net/download/zlb_lover/9654404)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Android webview中的图片点击事件](https://blog.csdn.net/weixin_42273922/article/details/106781799)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值