H5调用本地相册/相机上传图片

本文详细记录了H5如何调用Android的本地相册和相机功能进行图片上传的过程,包括H5中使用标签、Android端WebView的配置与监听,以及在Android 7.0以上版本的适配和文件选择后的处理。同时提到了选择图片后可能出现的只调用一次的问题,以及使用Luban库进行图片压缩的步骤。
摘要由CSDN通过智能技术生成

在开发中有时候会用到H5调用本地图片或者相机,像第三方的实名认证,在线客服等等都需要上传图片。H5中只需要通过<input>调用即可,ios是可以的实现的,不需要自己处理,除非客户端压缩图片,但是Android中需要自己处理,比较坑,本文记录H5调用本地图片或者相机的实现过程以及遇到的问题。

先看效果图

H5

H5主要是通过input标签来获取图片

 <input class="upload-input"  accept="image/*" multiple required type="file" @change="chooseImg">

Android

通过WebView加载h5页面,监听WebView对应的方法,实现自己的逻辑。

WebView初始化,放开对应的权限

private fun initWebView() {
        val settings = mWebView.settings
        settings.javaScriptEnabled = true
        settings.javaScriptCanOpenWindowsAutomatically = true
        //自适应屏幕
        settings.layoutAlgorithm = SINGLE_COLUMN
        settings.loadWithOverviewMode = true
        settings.domStorageEnabled = true
        settings.databaseEnabled = true
        settings.setSupportZoom(false)
        mWebView.isHorizontalScrollBarEnabled = false
        mWebView.isVerticalScrollBarEnabled = false
        mWebView.webViewClient = webViewClient
        mWebView.webChromeClient = webViewChromeClient
}

设置WebChromeClient

当点击input标签的时候会调用WebChromeClientonShowFileChooser()方法(5.0+)或者

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值