0


音频编辑服务UI SDK接入指导及常见问题

华为 HMS Core 音频编辑服务(Audio Editor Kit)是华为帮助全球开发者快速构建各类应用音频能力的服务,汇聚了华为在音乐、语音等相关音频领域的先进技术。音频编辑服务为开发者们提供音频基础编辑、AI配音、音源分离、空间渲染、变声、多种音效等丰富的音频处理能力,以及性能优异、简单易用、开放性强的接口,开发者们可依据应用场景,在App中高效轻松完成音频功能的集成。

音频编辑UI SDK提供产品级UI界面,集成接入简单、快速。

开发准备

1、配置AppGallery Connect

2、配置HMS Core SDK的Maven仓地址

3、集成HMS Core SDK

4、在“AndroidManifest.xml”文件中添加相关权限。

说明:如果应用集成的Android SDK版本为29及以上时,还需要在AndroidManifest.xml的application节点下新增以下属性,以获取访问外部存储文件的权限。

  1. <application
  2. android:requestLegacyExternalStorage="true"
  3. …… >

支持的设备

REST

Android:

华为手机 EMUI5.0 及以上

非华为手机 Android7.0 及以上

SDK集成开发

1、初始化SDK,设置应用的鉴权信息,如果不设置将影响部分功能的使用。

  1. // 获取agconnect-services.json文件中的api_key。
  2. // 正式应用中建议将api_key存储在云侧,运行时在进行获取。
  3. String api_key = AGConnectInstance.getInstance().getOptions().getString("client/api_key");
  4. // 设置api_key
  5. HAEApplication.getInstance().setApiKey(api_key);

2、创建AudioFilePickerActivity,此Activity为自定义Activity,用于音频文件选择。

  1. /**
  2. * 自定义Activity界面,用于音频文件的选择
  3. */
  4. public class AudioFilePickerActivity extends AppCompatActivity {
  5. @Override
  6. protected void onCreate(@Nullable Bundle savedInstanceState) {
  7. super.onCreate(savedInstanceState);
  8. performFileSearch();
  9. }
  10. private void performFileSearch() {
  11. // 选择多个音频文件
  12. registerForActivityResult(new ActivityResultContracts.GetMultipleContents(), new ActivityResultCallback<List<Uri>>() {
  13. @Override
  14. public void onActivityResult(List<Uri> result) {
  15. handleSelectedAudios(result);
  16. finish();
  17. }
  18. }).launch("audio/*");
  19. }
  20. /**
  21. * 处理选定的音频,将Uri转成需要的路径
  22. *
  23. * @param uriList 选中的音频文件
  24. */
  25. private void handleSelectedAudios(List<Uri> uriList) {
  26. // 判断是否存在音频文件
  27. if (uriList == null || uriList.size() == 0) {
  28. return;
  29. }
  30. ArrayList<String> audioList = new ArrayList<>();
  31. for (Uri uri : uriList) {
  32. // 获取真实路径
  33. String filePath = FileUtils.getRealPath(this, uri);
  34. audioList.add(filePath);
  35. }
  36. // 将音频文件路径返回给音频编辑页面
  37. Intent intent = new Intent();
  38. // 使用SDK提供的HAEConstant.AUDIO_PATH_LIST
  39. intent.putExtra(HAEConstant.AUDIO_PATH_LIST, audioList);
  40. // 使用SDK提供的HAEConstant.RESULT_CODE为结果CODE
  41. this.setResult(HAEConstant.RESULT_CODE, intent);
  42. finish();
  43. }
  44. }

获取真实路径时用到的FileUtils工具类,可以在示例代码中查看,工具类路径为:

  1. app/src/main/java/com/huawei/hms/audioeditor/demo/util/FileUtils.java

3、在“AndroidManifest.xml”中为AudioFilePickerActivity添加action值,SDK将根据此action进行跳转。

  1. <activity
  2. android:name=".AudioFilePickerActivity"
  3. android:exported="false">
  4. <intent-filter>
  5. <action android:name="com.huawei.hms.audioeditor.chooseaudio" />
  6. <category android:name="android.intent.category.DEFAULT" />
  7. </intent-filter>
  8. </activity>

4、启动音频编辑页面。

方式一:不带入参的启动方式,使用SDK提供的默认配置,方便快捷。

  1. HAEUIManager.getInstance().launchEditorActivity(this);

方式二:带入参的启动方式,支持设置菜单列表、自定义导出文件路径、音频文件路径、草稿模式等。

1、 带菜单列表以及自定义导出文件路径的启动方式:

  1. // 一级菜单列表(以下菜单列表仅为部分示例)
  2. ArrayList<Integer> menuList = new ArrayList<>();
  3. // 添加音频
  4. menuList.add(MenuCommon.MAIN_MENU_ADD_AUDIO_CODE);
  5. // 录音
  6. menuList.add(MenuCommon.MAIN_MENU_AUDIO_RECORDER_CODE);
  7. // 二级菜单列表(以下菜单列表仅为部分示例),导入音频后,选中音频时展示
  8. ArrayList<Integer> secondMenuList = new ArrayList<>();
  9. // 分割
  10. secondMenuList.add(MenuCommon.EDIT_MENU_SPLIT_CODE);
  11. // 删除
  12. secondMenuList.add(MenuCommon.EDIT_MENU_DEL_CODE);
  13. // 音量
  14. secondMenuList.add(MenuCommon.EDIT_MENU_VOLUME2_CODE);
  15. // 自定义导出路径
  16. String exportPath = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_MUSIC).getPath() + "/";
  17. AudioEditorLaunchOption.Builder audioEditorLaunch = new AudioEditorLaunchOption.Builder()
  18. // 设置一级菜单
  19. .setCustomMenuList(menuList)
  20. // 设置二级菜单
  21. .setSecondMenuList(secondMenuList)
  22. // 设置导出路径
  23. .setExportPath(exportPath);
  24. // 带菜单列表以及自定义音频文件导出路径的启动方式
  25. try {
  26. HAEUIManager.getInstance().launchEditorActivity(this, audioEditorLaunch.build(), new LaunchCallback() {
  27. @Override
  28. public void onFailed(int errCode, String errMsg) {
  29. Toast.makeText(mContext, errMsg, Toast.LENGTH_SHORT).show();
  30. }
  31. });
  32. } catch (IOException e) {
  33. e.printStackTrace();
  34. }

下图为一级菜单和二级菜单样式:

  1. ![](https://img-blog.csdnimg.cn/a84c81e1a5e24c8f80b34f0c2ade3dea.png)
  2. ![](https://img-blog.csdnimg.cn/9c10af80803843eeb7ebeebb8c61f41d.png)

2、 带音频文件路径的启动方式。

  1. // 设置音频导入路径
  2. ArrayList<AudioInfo> audioInfoList = new ArrayList<>();
  3. // 音频路径,以实际路径为准。
  4. String audioPath = "/storage/emulated/0/Music/Dream_It_Possible.flac";
  5. // 创建AudioInfo实例,并传入音频路径。
  6. AudioInfo audioInfo = new AudioInfo(audioPath);
  7. // 设置音频名字
  8. audioInfo.setAudioName("Dream_It_Possible");
  9. audioInfoList.add(audioInfo);
  10. AudioEditorLaunchOption.Builder audioEditorLaunch = new AudioEditorLaunchOption.Builder()
  11. // 设置音频导入路径
  12. .setFilePaths(audioInfoList);
  13. // 带音频文件路径的启动方式
  14. try {
  15. HAEUIManager.getInstance().launchEditorActivity(this, audioEditorLaunch.build(), new LaunchCallback() {
  16. @Override
  17. public void onFailed(int errCode, String errMsg) {
  18. Toast.makeText(mContext, errMsg, Toast.LENGTH_SHORT).show();
  19. }
  20. });
  21. } catch (IOException e) {
  22. e.printStackTrace();
  23. }

带音频文件路径的启动方式,启动音频编辑页面后会直接进入二级菜单。

3、 带草稿的启动方式。

  1. // 获取草稿列表,此处只做演示使用
  2. List<DraftInfo> draftList = HAEUIManager.getInstance().getDraftList();
  3. // 指定草稿列表的第一个草稿
  4. String draftId = null;
  5. if (!draftList.isEmpty()) {
  6. draftId = draftList.get(0).getDraftId();
  7. }
  8. AudioEditorLaunchOption.Builder audioEditorLaunch = new AudioEditorLaunchOption.Builder()
  9. // 设置草稿ID,可以为null
  10. .setDraftId(draftId)
  11. // 设置草稿模式,默认值为NOT_SAVE:不保存。
  12. .setDraftMode(AudioEditorLaunchOption.DraftMode.SAVE_DRAFT);
  13. // 带草稿的启动方式
  14. try {
  15. HAEUIManager.getInstance().launchEditorActivity(this, audioEditorLaunch.build(), new LaunchCallback() {
  16. @Override
  17. public void onFailed(int errCode, String errMsg) {
  18. Toast.makeText(mContext, errMsg, Toast.LENGTH_SHORT).show();
  19. }
  20. });
  21. } catch (IOException e) {
  22. e.printStackTrace();
  23. }

演示Demo

常见问题

Q1:添加音效、AI配音等功能提示“Token过期或非法”。

请检查鉴权信息是否配置,如果未配置,可以参考此链接进行配置。

一般在日志中会有如下提示:HAEApplication: please set your app apiKey。

Q2:在进行相关操作时,提示“内部错误”。

1、检查鉴权信息是否配置。

2、在AppGallery Connect中检查应用的音频编辑服务开关是否开启。如果未开启,可以参考此链接进行开启,开关开启后受缓存影响,一般需要等待一段时间才会生效。

了解更多详情>>

访问华为开发者联盟官网
获取开发指导文档
华为移动服务开源仓库地址:GitHub、Gitee

关注我们,第一时间了解 HMS Core 最新技术资讯~

标签: android 移动开发

本文转载自: https://blog.csdn.net/HUAWEI_HMSCore/article/details/128816756
版权归原作者 HMS Core 所有, 如有侵权,请联系我们删除。

“音频编辑服务UI SDK接入指导及常见问题”的评论:

还没有评论