关于在Android webView中调用Android本地的文件图片等选择器

在WebView移动端适配中,遇到前端H5无法直接弹出Android文件选择器的问题。解决方法是在`onShowFileChooser`方法内处理,这里展示了如何调用文件选择器和相机功能。
摘要由CSDN通过智能技术生成

在初次接触到webView使用过程中,前端写H5界面的时候因为是在pc端进行,可以直接弹出文件选择器等工具进行操作,并没有什么问题发生,一切都很自然的进行。但是在进行手机端调试的时候就发现问题了,在手机无法直接调用android的文件图片等选择器,需要进行添加一些方法才行。

直接上代码

主要的就是在onShowFileChooser里面进行操作 这里只调用了文件选择器和相机。

    webView.setWebChromeClient(new WebChromeClient() {
        @Override
        public void onProgressChanged(WebView view, int newProgress) {
            super.onProgressChanged(view, newProgress);
        }

        @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
        @Override
        public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {
            fileCallback = filePathCallback;
            //FileSystem
            Intent i = new Intent(Intent.ACTION_GET_CONTENT);
            i.addCategory(Intent.CATEGORY_OPENABLE);
            i.setType("*/*");

            // Camera.
            Strin
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现网页通过 WebView 调用 Android图片文件选择,可以使用以下步骤: 1.在 Android 代码,为 WebView 设置 WebChromeClient,并重写 onShowFileChooser 方法。 2.在 onShowFileChooser 方法调用系统的文件选择器或图库,让用户选择要上传的文件图片。 3.将用户选择的文件图片返回给 WebView,并在 JavaScript 处理上传操作。 下面是实现步骤的示例代码: 1.在 Android 代码,为 WebView 设置 WebChromeClient,并重写 onShowFileChooser 方法。 ```java webView.setWebChromeClient(new WebChromeClient() { @Override public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { // 在这里调用系统的文件选择器或图库,让用户选择要上传的文件图片 return true; } }); ``` 2.在 onShowFileChooser 方法调用系统的文件选择器或图库,让用户选择要上传的文件图片。 ```java @Override public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { Intent intent = fileChooserParams.createIntent(); try { startActivityForResult(intent, REQUEST_CODE_UPLOAD_FILE); } catch (ActivityNotFoundException e) { e.printStackTrace(); } } return true; } ``` 3.将用户选择的文件图片返回给 WebView,并在 JavaScript 处理上传操作。 ```java @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_CODE_UPLOAD_FILE && resultCode == RESULT_OK) { Uri[] uris = new Uri[1]; uris[0] = data.getData(); if (mFilePathCallback != null) { mFilePathCallback.onReceiveValue(uris); } } } ``` 在 JavaScript ,可以通过监听 input[type=file] 的 change 事件,获取用户选择的文件图片。 ```javascript var fileInput = document.createElement('input'); fileInput.type = 'file'; fileInput.onchange = function() { var file = fileInput.files[0]; // 处理上传操作 }; fileInput.click(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值