安卓开发Webview RTC 适配

一、场景

在混合开发方式中,项目前端使用了tracking.js 开发了一个人脸识别功能,但是在安卓端无法成功调用摄像头进行视频捕获,在浏览器中可以正常使用该功能。

二、问题分析

之前的音视频文件适配提供给前端的方式,都是通过input标签,而这次前端的使用方式很明显不是这种,查了一下tracking.js的实现原理,得到了getUserMedia这种方式,在html5中的使用,进而才了解到webRTC适配这个事情, 安卓默认没有授权。

参考文章:

webview权限适配和getUserMedia适配 | hss01248's blog

最终在代码中需要进行授权适配以及webview 设置修改处理:

复制代码
WebSettings webSettings = mWebviewPage.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setMediaPlaybackRequiresUserGesture(false);
webSettings.setAllowContentAccess(true);
webSettings.setAllowFileAccess(true);
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE );
复制代码
//WebRTC 适配
//https://webrtc.github.io/samples/src/content/getusermedia/gum/
@Override
public void onPermissionRequest(PermissionRequest request) {
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        mWebRTCRequest = request;
        Log.d(TAG,"request getOrigin="+request.getOrigin());
        String[] permissonRes = request.getResources();
        //判断是否包含了视频 和 音频 两种,分别转化为对应的安卓权限
        boolean videoRequire = false;
        boolean audioRequire = false;
        for(String permission : permissonRes){
            Log.d(TAG,"request permission="+permission);
            if(permission.equals(PermissionRequest.RESOURCE_VIDEO_CAPTURE)){
                videoRequire = true;
            }else if (permission.equals(PermissionRequest.RESOURCE_AUDIO_CAPTURE)){
                audioRequire = true;
            }
        }
        //包含了音频则一定会要求视频
        if (audioRequire){
            boolean audioGranted =  HzNetUtil.selfPermissionGranted(mContext, Manifest.permission.RECORD_AUDIO);
            boolean cameraGranted =  HzNetUtil.selfPermissionGranted(mContext, android.Manifest.permission.CAMERA);
            if (audioGranted && cameraGranted){
                request.grant(request.getResources());
            }else {
                ActivityCompat.requestPermissions(WebViewActivity.this,
                        new String[]{android.Manifest.permission.CAMERA,
                                Manifest.permission.RECORD_AUDIO
                        }, Constants.PERMISSION_REQUEST_FOR_WEBVIEW_RTC);
            }
        }else {
            //只要视频
            boolean cameraGranted =  HzNetUtil.selfPermissionGranted(mContext, android.Manifest.permission.CAMERA);
            if (cameraGranted){
                request.grant(request.getResources());
            }else {
                ActivityCompat.requestPermissions(WebViewActivity.this,
                        new String[]{android.Manifest.permission.CAMERA
                        }, Constants.PERMISSION_REQUEST_FOR_WEBVIEW_RTC);
            }
        }
    }else {
        AFLog.w(TAG,"安卓低版本,不支持WebRTC");
    }
}

如此这般适配之后,基本可以正常通过webview 唤起摄像头进行业务功能了。

测试地址:
getUserMediaWebRTC code sampleshttps://webrtc.github.io/samples/src/content/getusermedia/gum/

相关推荐
云手机管家2 分钟前
自动化脚本开发:Python调用云手机API实现TikTok批量内容发布
android·网络安全·智能手机·架构·自动化
咕噜企业签名分发-淼淼31 分钟前
iOS苹果和Android安卓测试APP应用程序的区别差异
android·ios·cocoa
IT从业者张某某1 小时前
信奥赛-刷题笔记-栈篇-T2-P1165日志分析0519
android·java·笔记
androidwork2 小时前
Kotlin与物联网(IoT):Android Things开发探索
android·物联网·kotlin
橙子199110162 小时前
在 Kotlin 中,什么是内联函数?有什么作用?
android·开发语言·kotlin
悠哉清闲3 小时前
Kotlin 协程 (一)
android·开发语言·kotlin
草明3 小时前
使用 adb 命令截取 Android 设备的屏幕截图
android·adb
.生产的驴4 小时前
SpringBoot 商城系统高并发引起的库存超卖库存问题 乐观锁 悲观锁 抢购 商品秒杀 高并发
android·java·数据库·spring boot·后端·spring·maven
xihaowen4 小时前
Android Edge-to-Edge
android·前端·edge
WenGyyyL6 小时前
《Android 应用开发基础教程》——第十三章:权限管理机制与运行时权限请求(以拍照/存储为例)
android·java·权限·极限编程