HarmonyOS 使用web嵌入h5地址,h5里面视频摄像头,无法打开摄像头

使用web组件嵌入h5模块,h5模块里面有视频功能,发起视频通话,摄像头显示不了。

module.json5:

"requestPermissions": [{
  "name": "ohos.permission.INTERNET"
},{
  "name": "ohos.permission.CAMERA",
  "reason": "$string:EntryAbility_desc",
  "usedScene":
  {
    "abilities": [
    "EntryAbility"
    ]
  }
},{
  "name":
  "ohos.permission.MICROPHONE",
  "reason": "$string:EntryAbility_desc",
  "usedScene": {
    "abilities": [
    "EntryAbility"
    ]
  }
}]
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.

嵌入h5页面:

Web({
  src: this.H5Src,
  controller: this.webviewController
})
  .domStorageAccess(true)
  .fileAccess(true)
  .imageAccess(true)
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
HarmonyOS
2025-01-09 17:58:51
浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
Heiang

参考示例如下:

import web_webview from '@ohos.web.webview';
import abilityAccessCtrl, { PermissionRequestResult, Permissions } from '@ohos.abilityAccessCtrl';

@Entry
@Component
struct WebComponent {
  controller: web_webview.WebviewController = new web_webview.WebviewController()

  aboutToAppear() {
    // 配置Web开启调试模式
    web_webview.WebviewController.setWebDebuggingAccess(true);
    let atManager = abilityAccessCtrl.createAtManager();
    atManager.requestPermissionsFromUser(getContext(this), ['ohos.permission.CAMERA', 'ohos.permission.MICROPHONE'])
      .then(data => {
        let result: Array<number> = data.authResults;
        let hasPermissions1 = true;
        result.forEach(item => {
          if (item === -1) {
            hasPermissions1 = false;
          }
        })
        if (hasPermissions1) {
          console.info("hasPermissions1")
        } else {
          console.info(" not hasPermissions1")
        }
      }).catch(() => {
      return;
    });
  }

  build() {
    Column() {
      Web({ src: 'https://xxx ', controller: this.controller })
        .domStorageAccess(true)
        .javaScriptAccess(true)
        .fileAccess(true)
        .onPermissionRequest((event) => {
          if (event) {
            AlertDialog.show({
              title: 'title',
              message: 'text',
              primaryButton: {
                value: 'deny',
                action: () => {
                  event.request.deny()
                }
              },
              secondaryButton: {
                value: 'onConfirm',
                action: () => {
                  event.request.grant(event.request.getAccessibleResource())
                }
              },
              cancel: () => {
                event.request.deny()
              }
            })
          }
        })
    }
  }
}
  • 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.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
  • 58.
  • 59.
  • 60.
  • 61.
  • 62.
  • 63.
分享
微博
QQ
微信
回复
2025-01-09 20:06:22


相关问题
HarmonyOS web组件加载h5h5拉起摄像头
1217浏览 • 1回复 待解决
HarmonyOS 打开摄像头失败
538浏览 • 1回复 待解决
HarmonyOS化flutter无法打开摄像头
528浏览 • 1回复 待解决
HarmonyOS 获取摄像头能力
590浏览 • 1回复 待解决
HarmonyOS 相机打开之后如何切换摄像头
1084浏览 • 1回复 待解决
HarmonyOS 前置摄像头开启
694浏览 • 1回复 待解决
HarmonyOS 摄像头录制问题
650浏览 • 1回复 待解决
HarmonyOS 摄像头切换时卡死
504浏览 • 1回复 待解决
相机预览及切换摄像头
1602浏览 • 1回复 待解决
HarmonyOS 切换前置摄像头黑屏
462浏览 • 1回复 待解决
HarmonyOS 录制屏幕 录制摄像头咨询
938浏览 • 1回复 待解决
请问3.1如何调用摄像头
2904浏览 • 1回复 待解决
HarmonyOS 摄像头预览画面方向错误
796浏览 • 1回复 待解决
HarmonyOS 安全摄像头支持设备型号
397浏览 • 1回复 待解决
HiSpark_IPC_DIY 摄像头烧录失败
6258浏览 • 3回复 待解决