最近和三方公司H5某些业务进行对接,本来说的是直接用WebView加载这个H5界面就完事了,后面才发现他们的需求不止于此…项目写完了,那边才说需要调用摄像头进行识别拍照等等,然而我这边不处理的话webview是无法调用摄像头的.

开始说问题:
1.权限,我这里用到的:

<uses-permission android:name="android.permission.CAMERA" /><uses-permission android:name="android.permission.RECORD_AUDIO"/><uses-permission android:name="android.permission.WAKE_LOCK" /><uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

2.webview页面WebViewSettings:

        webView.requestFocusFromTouch();// 支持获取手势焦点,输入用户名、密码或其他String ua = webView.getSettings().getUserAgentString();webView.getSettings().setUserAgentString(ua+ "zdgj_1.0.0");WebSettings webSettings = webView.getSettings();webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件webSettings.setJavaScriptEnabled(true);//支持jswebSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口webSettings.setDatabaseEnabled(false);// 数据库缓存webSettings.setAppCacheEnabled(false);// 打开缓存webSettings.setDomStorageEnabled(true);// 打开dom storage缓存webSettings.setAllowFileAccess(true);  //设置可以访问文件webSettings.setAllowContentAccess(true); // 是否可访问Content Provider的资源,默认值 truewebSettings.setAllowFileAccess(true);    // 是否可访问本地文件,默认值 truewebSettings.setJavaScriptEnabled(true);// 允许网页与JS交互webSettings.setRenderPriority(WebSettings.RenderPriority.HIGH);// 提高渲染级别webSettings.setLoadsImagesAutomatically(true);// 自动加载网络图片webSettings.setDefaultTextEncodingName("utf-8");// 设置默认编码方式// 是否允许通过file url加载的Javascript读取本地文件,默认值 falsewebSettings.setAllowFileAccessFromFileURLs(false);// 是否允许通过file url加载的Javascript读取全部资源(包括文件,http,https),默认值 falsewebSettings.setAllowUniversalAccessFromFileURLs(false);// 支持缩放webSettings.setSupportZoom(true); webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);// 布局方式


这里对userAgent加了我们app的标识,方便三方公司的区分识别,不需要可以去掉

下面两个方法是提供给H5调用的

protected void initChildInfo() {webView.addJavascriptInterface(new onJavaScriptInterface(), "android");}private class onJavaScriptInterface {/*** 返回上个界面*/@JavascriptInterfacepublic void finishView() {webView.post(new Runnable() {@Overridepublic void run() {finish();}});}/*** 打电话*/@JavascriptInterfacepublic void callMobile(final String mobile) {webView.post(new Runnable() {@Overridepublic void run() {Intent intent = new Intent(Intent.ACTION_DIAL);Uri data = Uri.parse("tel:" + mobile);intent.setData(data);startActivity(intent);}});}}

3.最重要的自定义PaxWebChromeClient继承WebChromeClient :

public class PaxWebChromeClient extends WebChromeClient {private static final String TAG = "PaxWebChromeClient";private final static int VIDEO_REQUEST = 0x11;private final static int PHOTO_REQUEST = 0x22;private Activity mActivity;private ValueCallback<Uri> uploadFile;//定义接受返回值private ValueCallback<Uri[]> uploadFiles;private Uri imageUri;public PaxWebChromeClient(@NonNull Activity activity) {this.mActivity = activity;}@Overridepublic void onProgressChanged(WebView view, int newProgress) {super.onProgressChanged(view, newProgress);}@Overridepublic void onReceivedTitle(WebView view, String title) {super.onReceivedTitle(view, title);}@TargetApi(Build.VERSION_CODES.LOLLIPOP)@Overridepublic void onPermissionRequest(PermissionRequest request) {request.grant(request.getResources());}// For Android 3.0+public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType) {this.uploadFile = uploadMsg;openCamera(acceptType);}// For Android < 3.0public void openFileChooser(ValueCallback<Uri> uploadMsgs) {this.uploadFile = uploadMsgs;}// For Android  > 4.1.1
//    @Overridepublic void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture) {this.uploadFile = uploadMsg;openCamera(acceptType);}// For Android  >= 5.0@Override@SuppressLint("NewApi")public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, WebChromeClient.FileChooserParams fileChooserParams) {this.uploadFiles = filePathCallback;String[] acceptTypes = fileChooserParams.getAcceptTypes();for (int i = 0; i < acceptTypes.length; i++) {openCamera(acceptTypes[i]);LogUtils.e("类型类型类型:" + acceptTypes[i]);}return true;}private void openCamera(String accept) {if (accept.contains("image")) {//            image/*
//            File fileUri = new File(Environment.getExternalStorageDirectory().getPath() + "/" + SystemClock.currentThreadTimeMillis() + ".jpg");
//            imageUri = Uri.fromFile(fileUri);
//            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
//                imageUri = FileProvider.getUriForFile(mFragment.getActivity(), "com.mgyb.suning" + ".fileprovider", fileUri);//通过FileProvider创建一个content类型的Uri
//            }
//            PhotoUtils.takePicture(mFragment.getActivity(), imageUri, PHOTO_REQUEST);// 指定拍照存储位置的方式调起相机String filePath = Environment.getExternalStorageDirectory() + File.separator+ Environment.DIRECTORY_PICTURES + File.separator;String fileName = "IMG_" + DateFormat.format("yyyyMMdd_hhmmss", Calendar.getInstance(Locale.CHINA)) + ".jpg";imageUri = Uri.fromFile(new File(filePath + fileName));Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);intent.putExtra(MediaStore.EXTRA_OUTPUT, imageUri);mActivity.startActivityForResult(intent, PHOTO_REQUEST);} else if (accept.contains("video")) {//     video/*Intent intent = new Intent(MediaStore.ACTION_VIDEO_CAPTURE);// set the video file nameintent.putExtra(MediaStore.EXTRA_VIDEO_QUALITY, 0.5);//限制时长intent.putExtra(MediaStore.EXTRA_DURATION_LIMIT, 5);//开启摄像机mActivity.startActivityForResult(intent, VIDEO_REQUEST);}}public void onActivityResult(int requestCode, int resultCode, Intent data) {if (resultCode == RESULT_OK) {switch (requestCode) {case VIDEO_REQUEST:if (null != uploadFile) {Uri result = data == null || resultCode != RESULT_OK ? null : data.getData();uploadFile.onReceiveValue(result);uploadFile = null;}if (null != uploadFiles) {Uri result = data == null || resultCode != RESULT_OK ? null : data.getData();uploadFiles.onReceiveValue(new Uri[]{result});uploadFiles = null;}break;case PHOTO_REQUEST:if (null == uploadFile && null == uploadFiles) return;Uri result = data == null || resultCode != RESULT_OK ? null : data.getData();if (uploadFiles != null) {onActivityResultAboveL(requestCode, resultCode, data);} else if (uploadFile != null) {uploadFile.onReceiveValue(result);uploadFile = null;}break;default:break;}} else if (resultCode == Activity.RESULT_CANCELED) {if (null != uploadFile) {uploadFile.onReceiveValue(null);uploadFile = null;}if (null != uploadFiles) {uploadFiles.onReceiveValue(null);uploadFiles = null;}}}@TargetApi(Build.VERSION_CODES.LOLLIPOP)private void onActivityResultAboveL(int requestCode, int resultCode, Intent data) {if (requestCode != PHOTO_REQUEST || uploadFiles == null) {return;}Uri[] results = null;if (resultCode == Activity.RESULT_OK) {if (data == null) {results = new Uri[]{imageUri};} else {String dataString = data.getDataString();ClipData clipData = data.getClipData();if (clipData != null) {results = new Uri[clipData.getItemCount()];for (int i = 0; i < clipData.getItemCount(); i++) {ClipData.Item item = clipData.getItemAt(i);results[i] = item.getUri();}}if (dataString != null)results = new Uri[]{Uri.parse(dataString)};}}uploadFiles.onReceiveValue(results);uploadFiles = null;}
}

我在onShowFileChooser方法里对js的accept进行了处理,区别是录像还是拍照,然后在分别进行对应的操作

4.在webviewActivity 的 回调里调用 自定义chromeClient的onActivityResult()方法

@Overridepublic void onActivityResult(int requestCode, int resultCode, Intent data) {chromeClient.onActivityResult(requestCode, resultCode, data);super.onActivityResult(requestCode, resultCode, data);}

5.如需要返回键网页逐级返回,就在加个监听

 @Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) {// 处理返回键,在webview界面,按下返回键,不退出程序if (keyCode == KeyEvent.KEYCODE_BACK) {if (webView.canGoBack()) {webView.goBack();return true;} else {onActivityBackPressed();}}return super.onKeyDown(keyCode, event);}

6.最后附上webviewActivity代码:

public class WebViewActivity extends BaseActivity {private PaxWebChromeClient chromeClient;private String mUrl;private WebView webView;public static void start(Context context, String url) {Intent intent = new Intent(context, WebViewActivity.class);intent.putExtra("url", url);context.startActivity(intent);}@Overridepublic int getLayoutId() {return R.layout.activity_webview;}@Overrideprotected void initView(View rootView) {webView = (WebView) findViewById(R.id.webview);Intent intent = getIntent();mUrl = intent.getStringExtra("url");chromeClient = new PaxWebChromeClient(this);initWebViewSettings();webView.setWebChromeClient(chromeClient);webView.setWebViewClient(new MyWebViewClient());webView.loadUrl(mUrl);initChildInfo();}private void initWebViewSettings() {if (webView == null) {throw new NullPointerException("webview is null. please use initWebView(WebView webView) method");}webView.requestFocusFromTouch();// 支持获取手势焦点,输入用户名、密码或其他String ua = webView.getSettings().getUserAgentString();webView.getSettings().setUserAgentString(ua+ "zdgj_1.0.0");WebSettings webSettings = webView.getSettings();webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件webSettings.setJavaScriptEnabled(true);//支持jswebSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口webSettings.setDatabaseEnabled(false);// 数据库缓存webSettings.setAppCacheEnabled(false);// 打开缓存webSettings.setDomStorageEnabled(true);// 打开dom storage缓存webSettings.setAllowFileAccess(true);  //设置可以访问文件webSettings.setAllowContentAccess(true); // 是否可访问Content Provider的资源,默认值 truewebSettings.setAllowFileAccess(true);    // 是否可访问本地文件,默认值 truewebSettings.setJavaScriptEnabled(true);// 允许网页与JS交互webSettings.setRenderPriority(WebSettings.RenderPriority.HIGH);// 提高渲染级别webSettings.setLoadsImagesAutomatically(true);// 自动加载网络图片webSettings.setDefaultTextEncodingName("utf-8");// 设置默认编码方式// 是否允许通过file url加载的Javascript读取本地文件,默认值 falsewebSettings.setAllowFileAccessFromFileURLs(false);// 是否允许通过file url加载的Javascript读取全部资源(包括文件,http,https),默认值 falsewebSettings.setAllowUniversalAccessFromFileURLs(false);// 支持缩放webSettings.setSupportZoom(true);webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);// 布局方式}protected void initChildInfo() {webView.addJavascriptInterface(new onJavaScriptInterface(), "android");}private class onJavaScriptInterface {/*** 返回上个界面*/@JavascriptInterfacepublic void finishView() {webView.post(new Runnable() {@Overridepublic void run() {finish();}});}/*** 打电话*/@JavascriptInterfacepublic void callMobile(final String mobile) {webView.post(new Runnable() {@Overridepublic void run() {Intent intent = new Intent(Intent.ACTION_DIAL);Uri data = Uri.parse("tel:" + mobile);intent.setData(data);startActivity(intent);}});}}@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);}@Overridepublic void onActivityResult(int requestCode, int resultCode, Intent data) {chromeClient.onActivityResult(requestCode, resultCode, data);super.onActivityResult(requestCode, resultCode, data);}@Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) {// 处理返回键,在webview界面,按下返回键,不退出程序if (keyCode == KeyEvent.KEYCODE_BACK) {if (webView.canGoBack()) {webView.goBack();return true;} else {onActivityBackPressed();}}return super.onKeyDown(keyCode, event);}@Overridepublic void onPause() {super.onPause();webView.onPause();}@Overridepublic void onResume() {super.onResume();webView.onResume();}@Overridepublic void onDestroy() {super.onDestroy();try {webView.stopLoading();webView.getSettings().setJavaScriptEnabled(false);webView.clearHistory();webView.removeAllViews();webView.destroy();} catch (Exception e) {}}private class MyWebViewClient extends WebViewClient {@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {view.loadUrl(url);return true;}@Overridepublic void onPageFinished(WebView view, String url) {super.onPageFinished(view, url);hideStatusView();}}
}

到这里android 对 H5调用摄像头的处理就结束啦,感谢各位看官~

Android WebView调用摄像头录像拍照处理相关推荐

  1. Android关于第三方h5在webview调用摄像头及相机的处理

    参考资料: 深坑之Webview,解决H5调用android相机拍照和录像 除了没有适配6.0以上的动态申请以及拦截h5的方法不同,其余均参考以上文章 因为app和银行合作,在banner页投放了银行 ...

  2. 摄像头自建html直播,html5调用摄像头实现拍照

    html5调用摄像头实现拍照 拍照 var video=document.getElementById("video"); var context=canvas.getContex ...

  3. android调用chrome,android webview调用使用chrome浏览器

    我已经做了一个web应用程序,它在移动Chrome中工作正常,但在铬中我看到一些问题,所以可以从应用程序中调用android chrome而不是webview.android webview调用使用c ...

  4. 在网页中调用摄像头实现拍照上传 - 高拍仪二次开发

    在网页中调用摄像头实现拍照上传 高拍仪二次开发     在一些公共部门的办事处,比如银行.护照办理中心.税务等,我们可能会注意到办公桌上摆着这样一台机器.办公人员用它拍摄各种证件.文件.表格,有时候还 ...

  5. c++ 二次开发 良田高拍仪_在网页中调用摄像头实现拍照上传 - 高拍仪二次开发...

    来源于  https://blog.csdn.net/weixin_40659738/article/details/78252562 在网页中调用摄像头实现拍照上传 高拍仪二次开发 在一些公共部门的 ...

  6. Python+opencv调用摄像头实现拍照并保存

    Python+opencv调用摄像头实现拍照并保存 安装 OpenCV库 详细源码 注意事项 安装 OpenCV库 pip install opencv-python 详细源码 调用外接摄像头实现拍照 ...

  7. android webview打开相册,Android WebView调用本地相册的方法

    本文实例为大家分享了Android WebView调用本地相册的具体实现方法,供大家参考,具体内容如下 首先要知道android本身的WebView是并不支持调用手机文件并上传的,其次WebView的 ...

  8. Python进阶,使用 opencv 调用摄像头进行拍照

             opencv 支持 Python 版本的模块叫作 opencv-p hon ,可直接使用 pip install opencv-python 令进行安装,但常常会因为网络等问题导致失 ...

  9. vue中如何调用ios摄像头_如何使用Vue2.0调用摄像头进行拍照

    这次给大家带来如何使用Vue2.0调用摄像头进行拍照,使用Vue2.0调用摄像头进行拍照的注意事项有哪些,下面就是实战案例,一起来看一下. import {Exif} from './exif.js' ...

  10. python3 + opencv 调用摄像头录像后保存视频

    python3 + opencv 调用摄像头录像后保存视频 #!/usr/bin/python3 import cv2## opening videocapture cap = cv2.VideoCa ...

最新文章

  1. 开始使用linux的core文件
  2. C#进行Visio二次开发之知识点考核试题
  3. UVA 11645 Bits(组合数学)
  4. greenplum 安装笔记
  5. PCL点云库用Poisson网格化实现点云的表面重建
  6. 在服务器上打包部署springboot+vue的项目(一)启动tomcat后打开浏览器点击登录无反应 页面空白问题
  7. 使用mvc模式读取服务器上的文件,关于C#:如何使用asp.net MVC应用程序从服务器上的网络路径读取...
  8. 最近微信方面的更新   getUserInfo:fail scope unauthorized
  9. asp.net中两款文本编辑器NicEdit和Kindeditor
  10. JavaScript之继承模式,命名空间,对象枚举
  11. 计算两个日期相差的天数,Calendar用法
  12. Tclientdate的排序
  13. 标准9针串口引脚定义
  14. python开发单片机仿真软件_开源电子电路仿真模拟软件,加油国产芯片
  15. mimax 刷原生android,小米手机想爽刷原生安卓?不愁!
  16. 2022ICPC预选赛 A Yet Another Remainder(数学)(构造)
  17. bartender打印错误
  18. 数据分析离不开商业分析
  19. 无法定位程序输入点,于动态链接库xxx上的可能原因及解决方法
  20. Unity中的Transform Gizmo中的Pivot和Center

热门文章

  1. OpenGL 高质量纹理过滤的实例
  2. 题6.12:有一行电文,已按照下面规律翻译成密码: A->Z a->z B->Y b->y C->X c->x即第1个字母编程第26个字母,第i个字母编程第(26-i+1)个字母,非字母字符不变,要求
  3. html怎么把正方形改成圆形,css如何把正方形变成圆形
  4. linux开pulseaudio服务,PulseAudio
  5. Python:利用Entrez库筛选下载PubMed文献摘要
  6. 智能家居产业现状总结
  7. lumion渲染太慢、卡顿怎么办?分享3个加快渲染的小技巧
  8. 基于javaweb+jsp的学生档案管理系统(JavaWeb JSP MySQL Servlet SSM SpringBoot Bootstrap)
  9. Atitit 档案学 档案管理 attilax学习总结
  10. html自动改成繁体怎么做,如何将繁体字转换成简体字,繁体字转换器在线转换,简体字转换为繁体字...