一、需要实现的功能:
用H5实现的App中需要在H5获取手机中的照片或者视频文件上传到服务器。
二、分析实现方法:
由于不懂前端开发,不知道H5中有 input file之类的标签控件,可以用来选择文件,刚开始的思路还是想着native 端是否要通过提供inputstream流方式,将文件内容传递给JS。后来和前端沟通之后,H5在电脑端都是用input 设置type为 file 来实现文件选择功能,于是才开始搜索资料,发现时需要在webview中设置 setWebChromeClient ,其中有对input 的响应回调:
三、具体实现:
前端代码
1 |
native端代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 | @RequiresApi (api = Build.VERSION_CODES.LOLLIPOP) @Override public boolean onShowFileChooser(WebView webView, ValueCallback filePathCallback, WebChromeClient.FileChooserParams fileChooserParams) { mFilePathCallbacks = filePathCallback; // TODO: 根据标签中得接收类型,启动对应的文件类型选择器 String[] acceptTypes = fileChooserParams.getAcceptTypes(); for (String type : acceptTypes) { Log.d(TAG, "acceptTypes=" + type); } // 针对拍照后马上进入上传状态处理 if ((acceptTypes.length > 0 ) && acceptTypes[ 0 ].equals( "image/example" )) { Log.d(TAG, "onShowFileChooser takePhoto" ); Intent it = CameraFunction.takePhoto(mContext); startActivityForResult(it, TAKE_PHOTO_AND_UPLOAD_REQUEST); return true ; } // 针对录像后马上进入上传状态处理 if ((acceptTypes.length > 0 ) && acceptTypes[ 0 ].equals( "video/example" )) { Log.d(TAG, "onShowFileChooser record video" ); Intent it = CameraFunction.recordVideo(mContext); startActivityForResult(it, RECORD_VIDEO_AND_UPLOAD_REQUEST); return true ; } Intent intent = new Intent(Intent.ACTION_GET_CONTENT); intent.addCategory(Intent.CATEGORY_OPENABLE); if (acceptTypes.length > 0 ) { if (acceptTypes[ 0 ].contains( "image" )) { intent.setType( "image/*" ); } else if (acceptTypes[ 0 ].contains( "video" )) { intent.setType( "video/*" ); } else { intent.setType( "*/*" ); } } else { intent.setType( "*/*" ); } WebViewActivity. this .startActivityForResult(Intent.createChooser(intent, "File Chooser" ), REQUEST_FILE_PICKER); return true ; } |
回调设置uri
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | /** * 设置input 标签出发的回调选择文件路径,优先使用path参数, * 其次使用uri参数 * @param uriParam * @param pathParam */ private void setFilePathCallback(Uri uriParam, String pathParam) { //都为空,则设置null if (uriParam == null && pathParam == null ) { if (mFilePathCallback != null ) { mFilePathCallback.onReceiveValue( null ); } if (mFilePathCallbacks != null ) { mFilePathCallbacks.onReceiveValue( null ); } } else if ( null != pathParam) { // 优先使用path if (mFilePathCallback != null ) { Uri uri = Uri.fromFile( new File(pathParam)); mFilePathCallback.onReceiveValue(uri); } if (mFilePathCallbacks != null ) { Uri uri = Uri.fromFile( new File(pathParam)); mFilePathCallbacks.onReceiveValue( new Uri[] { uri }); } } else if ( null != uriParam) { //其次使用uri if (mFilePathCallback != null ) { String path = UriUtils.getPath(getApplicationContext(), uriParam); Uri uri = Uri.fromFile( new File(path)); mFilePathCallback.onReceiveValue(uri); } if (mFilePathCallbacks != null ) { String path = UriUtils.getPath(getApplicationContext(), uriParam); Uri uri = Uri.fromFile( new File(path)); mFilePathCallbacks.onReceiveValue( new Uri[] { uri }); } } mFilePathCallback = null ; mFilePathCallbacks = null ; } |
针对各个请求场景进行处理:
1 | public void onActivityResult( int requestCode, int resultCode, Intent intent) { |
总结:既然用H5开发APP,就需要了解前端,不懂就要问了。查询方向要对,否则南辕北辙,方向有时候比努力重要!
到此这篇关于关于webview适配H5上传照片或者视频文件的方法的文章就介绍到这了,更多相关webview适配H5上传照片内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章,希望大家以后多多支持IT俱乐部!