HarmonyOS 音频录制与播放模块

HarmonyOS 音频录制与播放模块

1.模块功能概览

  • 麦克风权限动态检测与申请
  • 音频录制功能(支持参数配置)
  • 音频波形实时可视化(暂时未完善,先凑合看,后续会完善)
  • 录音文件播放功能

2.权限检测流程

1.代码实现

typescript 复制代码
async checkPermission() {
  const manager = abilityAccessCtrl.createAtManager();
  
  // 首次权限申请
  const result = await manager.requestPermissionsFromUser(
    getContext(), ["ohos.permission.MICROPHONE"]
  );

  // 检查所有权限是否通过
  const isPass = result.authResults.every(
    res => res === abilityAccessCtrl.GrantStatus.PERMISSION_GRANTED
  );

  if (!isPass) {
    // 二次弹窗引导设置
    const confirm = await promptAction.showDialog({...});
    
    if (confirm.index === 1) {
      // 跳转系统设置
      const finalResult = await manager.requestPermissionOnSetting(
        getContext(), ["ohos.permission.MICROPHONE"]
      );
    }
  }
}

2.2. 权限状态处理

状态 处理方式
第一次授权成功 直接启用录音功能
第一次授权失败 弹窗提示前往系统设置
系统设置二次授权失败 返回上级页面

3. 录音功能核心实现

1.录音机配置
ts 复制代码
// 创建文件描述符
const file = fileIo.openSync(filePath, 
  fileIo.OpenMode.CREATE | fileIo.OpenMode.READ_WRITE);

// AVRecorder 参数配置
const config = {
  audioSourceType: media.AudioSourceType.AUDIO_SOURCE_TYPE_MIC,
  url: `fd://${file.fd}`,
  profile: {
    audioBitrate: 100000,
    audioChannels: 2,
    audioSampleRate: 48000,
    audioCodec: media.CodecMimeType.AUDIO_AAC,
    fileFormat: media.ContainerFormatType.CFT_MPEG_4A
  }
};

2.录音操作控制

方法 功能描述
startRecord() 创建文件句柄/配置参数/启动录音
stopRecord() 停止录音/释放资源/关闭文件

3.音频播放实现

ts 复制代码
async playRecord() {
  const avPlayer = await media.createAVPlayer();
  avPlayer.url = `fd://${file.fd}`;
  
  avPlayer.on('stateChange', (state) => {
    if (state === 'initialized') {
      avPlayer.prepare();
    } else if (state === 'prepared') {
      avPlayer.play(); // 自动播放
    }
  });
}

4.效果展示

相关推荐
lbb 小魔仙6 小时前
【HarmonyOS实战】React Native 表单实战:在 OpenHarmony 上构建高性能表单
react native·华为·harmonyos
上海合宙LuatOS8 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
一只大侠的侠8 小时前
React Native开源鸿蒙跨平台训练营 Day16自定义 useForm 高性能验证
flutter·开源·harmonyos
早點睡3909 小时前
高级进阶 React Native 鸿蒙跨平台开发:@react-native-community-slider 滑块组件
react native·react.js·harmonyos
Android系统攻城狮9 小时前
Android16进阶之音频播放定位MediaPlayer.seekTo调用流程与实战(二百二十七)
音视频·mediaplayer·android16·音频进阶·音频性能实战
一只大侠的侠10 小时前
Flutter开源鸿蒙跨平台训练营 Day11从零开发商品详情页面
flutter·开源·harmonyos
一只大侠的侠10 小时前
React Native开源鸿蒙跨平台训练营 Day18自定义useForm表单管理实战实现
flutter·开源·harmonyos
一只大侠的侠10 小时前
React Native开源鸿蒙跨平台训练营 Day20自定义 useValidator 实现高性能表单验证
flutter·开源·harmonyos
晚霞的不甘10 小时前
Flutter for OpenHarmony 可视化教学:A* 寻路算法的交互式演示
人工智能·算法·flutter·架构·开源·音视频
听麟11 小时前
HarmonyOS 6.0+ 跨端智慧政务服务平台开发实战:多端协同办理与电子证照管理落地
笔记·华为·wpf·音视频·harmonyos·政务