安卓开发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 小时前
AIDL Hal 开发笔记6----添加硬件访问服务
android·framework·hal
诸神黄昏EX2 小时前
Android OTA 之 升级包编译机制
android
2501_915909063 小时前
苹果iOS应用上架详细流程与注意事项解析
android·ios·小程序·https·uni-app·iphone·webview
AC赳赳老秦4 小时前
跨境科技服务的基石:DeepSeek赋能多语言技术文档与合规性说明的深度实践
android·大数据·数据库·人工智能·科技·deepseek·跨境
晚霞的不甘4 小时前
解决 Flutter for OpenHarmony 构建失败:HVigor ERROR 00303168 (SDK component missing)
android·javascript·flutter
2501_944521594 小时前
Flutter for OpenHarmony 微动漫App实战:分享功能实现
android·开发语言·javascript·flutter·ecmascript
kekegdsz5 小时前
Android构建优化:编译速度从 10 分钟编译到 10 秒
android·性能优化·gradle
2501_944521595 小时前
Flutter for OpenHarmony 微动漫App实战:标签筛选功能实现
android·开发语言·前端·javascript·flutter
mjhcsp5 小时前
如何做一个网站?
android
2501_915909065 小时前
在无需越狱的前提下如何对 iOS 设备进行文件管理与数据导出
android·macos·ios·小程序·uni-app·cocoa·iphone