自 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” 菜单,新建工程。
选择项目模版为 “Empty Ability”。
填写您项目名称、设备类型等信息。
最后单击 “Finish” ,完成新工程创建。
2 导入 SDK
开发者可通过复制 SDK 文件手动集成 SDK。
- 下载 SDK 包 https://storage.zego.im/rtc/ZegoExpressVideo/ohos/ZegoExpressVideo-ohos-shared-ets.zip,下载最新版本的 SDK。
- 解压 SDK 至 “entry/libs” 项目目录。如果您的项目中没有 libs 目录,手动新建一个即可。
3. 进入 “entry” 目录,打开 “oh-package.json5” 文件,在 “dependencies” 节点中引入 “libs” 下所有的 har,添加 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