如何接入 HarmonyOS 音视频SDK?快速实现音视频通话

自 ZEGO HarmonyOS 音视频SDK 公测以来,目前有很多客户完成音视频能力的基本接入。当然接入的过程中也会碰到一些问题,本文将详细介绍HarmonyOS 音视频SDK的接入方式,方便开发者测试音视频通话功能。

准备环境

在开始集成 ZEGO 音视频SDK(Express SDK) 前,请确保开发环境满足以下要求:

  • 已联系华为商务人员,签署合作计划,开通相关权限,获取 DevEco Studio 4.1.3.600 Release 或以上版本。
  • 获取配套 API Version 11 的 HarmonyOS NEXT SDK 或以上版本。
  • 获取配套 API Version 11 的 HarmonyOS NEXT 2.0.0.59 操作系统或以上版本,支持音视频的鸿蒙设备,且已开启“允许调试”选项。
  • 如果需要使用真机调试,请参考鸿蒙官网文档进行配置。
  • 鸿蒙设备已经连接到 Internet。
  • 已注册华为开发者账号并完成实名认证。

集成 SDK

1 (可选)新建项目

打开 DevEco Studio,选择 “File > New > Create Project” 菜单,新建工程。

如何接入 HarmonyOS 音视频SDK?快速实现音视频通话

选择项目模版为 “Empty Ability”。

如何接入 HarmonyOS 音视频SDK?快速实现音视频通话

填写您项目名称、设备类型等信息。

如何接入 HarmonyOS 音视频SDK?快速实现音视频通话

最后单击 “Finish” ,完成新工程创建。

2 导入 SDK

开发者可通过复制 SDK 文件手动集成 SDK。

  1. 下载 SDK 包 https://storage.zego.im/rtc/ZegoExpressVideo/ohos/ZegoExpressVideo-ohos-shared-ets.zip,下载最新版本的 SDK。
  2. 解压 SDK 至 “entry/libs” 项目目录。如果您的项目中没有 libs 目录,手动新建一个即可。
如何接入 HarmonyOS 音视频SDK?快速实现音视频通话

3. 进入 “entry” 目录,打开 “oh-package.json5” 文件,在 “dependencies” 节点中引入 “libs” 下所有的 har,添加 SDK 引用。

如何接入 HarmonyOS 音视频SDK?快速实现音视频通话

设置权限

根据实际应用需要,设置应用所需权限。

进入 “entry/src/main” 目录,打开 “module.json5” 文件,在 “module” 节点中引入 requestPermissions,添加相关权限。

{
    "requestPermissions": [
      {
        "name": "ohos.permission.MICROPHONE",  // 麦克风权限
        "reason": "$string:app_name",
        "usedScene": {
          "abilities": [
            "EntryAbility"
          ],
          "when": "inuse"
        }
      },
      {
        "name": "ohos.permission.INTERNET",  // 网络权限
        "reason": "$string:app_name",
        "usedScene": {
          "abilities": [
            "EntryAbility"
          ],
          "when": "always"
        }
      },
      {
        "name": "ohos.permission.CAMERA",  // 摄像头权限
        "reason": "$string:app_name",
        "usedScene": {
          "abilities": [
            "EntryAbility"
          ],
          "when": "inuse"
        }
      },
      {
        "name": "ohos.permission.ACCESS_BLUETOOTH",  // 蓝牙权限
        "reason": "$string:app_name",
        "usedScene": {
          "abilities": [
            "EntryAbility"
          ],
          "when": "always"
        }
      },
      {
        "name": "ohos.permission.GET_NETWORK_INFO",  // 网络信息权限
        "reason": "$string:app_name",
        "usedScene": {
          "abilities": [
            "EntryAbility"
          ],
          "when": "always"
        }
      }
    ]
}

注意:

  • 鸿蒙系统上,敏感权限基于用户可知可控的原则需动态申请,申请方式参考如下代码。
  • 请确保预览或推拉流前应用已获取摄像头和麦克风权限,否则可能导致无法正常预览或推拉流。
// 首先导入权限相关包
import { AbilityConstant, UIAbility, Want, abilityAccessCtrl, Permissions} from '@kit.AbilityKit';

// 在加载界面完成后进行权限申请或者按需权限申请,可以在 windowStage.loadContent() 中添加以下代码
let atManager = abilityAccessCtrl.createAtManager();
const permissionList: Array<Permissions> = [
    'ohos.permission.INTERNET',
    'ohos.permission.CAMERA',
    'ohos.permission.MEDIA_LOCATION',
    'ohos.permission.MICROPHONE',
    'ohos.permission.READ_MEDIA',
    'ohos.permission.WRITE_MEDIA',
    'ohos.permission.READ_IMAGEVIDEO',
    'ohos.permission.WRITE_IMAGEVIDEO',
    'ohos.permission.GET_NETWORK_INFO',
    'ohos.permission.GET_NETWORK_STATS',
    'ohos.permission.ENTERPRISE_GET_NETWORK_INFO',
    'ohos.permission.ENTERPRISE_MANAGE_NETWORK',
];
atManager.requestPermissionsFromUser(this.context, permissionList).then((data) => {
    console.info('data:' + JSON.stringify(data));
    console.info('data permissions:' + data.permissions);
    console.info('data authResults:' + data.authResults);
}).catch((err: BusinessError) => {
    console.log(`NormalCapturer:createAudioCapturer err code:` + err.code + 'err msg:' + err.message);
    console.log(`NormalCapturer:createAudioCapturer err=${JSON.stringify(err)}`);
});

通过以上方式即可完成 SDK 接入。

关于如何实现音视频通话功能,可详细阅读:HarmonyOS 实现视频通话

本文为原创稿件,版权归作者所有,如需转载,请注明出处:https://www.nxrte.com/jishu/yinshipin/48213.html

(0)

相关推荐

发表回复

登录后才能评论