热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

iOS录音的常用设置ObjectiveC

本章涉及关于录音的以下几个要点·构建录音环境·录音录音介绍在iOS中录音的方法有很多这里采用了AVFoundation框架中的AVAudioRecorder类构建录音环境构建录音环

本章涉及关于录音的以下几个要点
· 构建录音环境
· 录音

录音介绍

在iOS中录音的方法有很多
这里采用了AVFoundation框架中的AVAudioRecorder

构建录音环境

构建录音环境其实就是对录音进行初始化。
录音初始化包括:
· 判断设备录音权限
· 创建AVAudioRecorder对象
· 指定文件路径
· 设置录音参数、属性、代理。
权限判断

- (BOOL)checkPermission {
AVAudioSessionRecordPermission permission = [[AVAudioSession sharedInstance] recordPermission];
return permission == AVAudioSessionRecordPermissionGranted;
}

AVAudioSessionRecordPermission枚举有三个参数 分别是未验证、未通过和通过。
未验证的时候需要提示用户点击确认允许软件访问麦克风。

[AVCaptureDevice requestAccessForMediaType:AVMediaTypeAudio completionHandler:^(BOOL granted) {
if (granted) {
// 通过验证
} else {
// 未通过验证
}
}];

在info.plist添加下面的代码,否则在iOS9.0以后的设备中无法录音。

// SourceCode
NSMicrophoneUsageDescription
随意填写(例:访问麦克风权限)
// PropertyList
Key:Privacy - Microphone Usage Description
Value:随意填写(例:访问麦克风权限)

配置录音:

- (BOOL)configRecorder {
// ...其他设置
NSURL *fileUrl = [NSURL fileURLWithPath:[self filePathWithName:[self newRecorderName]]];
NSError *error = nil;
NSDictionary *setting = [self recordSetting];
_recorder = [[AVAudioRecorder alloc] initWithURL:fileUrl settings:setting error:&error];
if (error) // 录音文件创建失败处理
_recorder.delegate = self
_recorder.meteringEnabled = YES;
// ...其他设置
}

// 录音参数设置
- (NSDictionary *)recordSetting {
NSMutableDictionary *recSetting = [[NSMutableDictionary alloc] init];
// General Audio Format Settings
recSetting[AVFormatIDKey] = @(kAudioFormatLinearPCM);
recSetting[AVSampleRateKey] = @44100;
recSetting[AVNumberOfChannelsKey] = @2;
// Linear PCM Format Settings
recSetting[AVLinearPCMBitDepthKey] = @24;
recSetting[AVLinearPCMIsBigEndianKey] = @YES;
recSetting[AVLinearPCMIsFloatKey] = @YES;
// Encoder Settings
recSetting[AVEncoderAudioQualityKey] = @(AVAudioQualityMedium);
recSetting[AVEncoderBitRateKey] = @128000;
return [recSetting copy];
}

// 录音文件的名称使用时间戳+caf后缀
- (NSString *)newRecorderName {
NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
formatter.dateFormat = @"yyyyMMddhhmmss";
return [[formatter stringFromDate:[NSDate date]] stringByAppendingPathExtension:@"caf"];
}
// Document目录
- (NSString *)filePathWithName:(NSString *)fileName {
NSString *urlStr = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
return [urlStr stringByAppendingPathComponent:fileName];
}

  • 使用prepareRecord方法来确保录音文件和参数被正确配置,如果有问题会返回NO。通常出现NO的原因是参数部分出现问题,可能少了某个必要的参数。

录音准备工作结束后就可以开始录音过程了
使用record方法开始录音,pause方法暂停录音,stop结束录音。
在暂停后继续录音直接调用recordaudioSession会帮助记录暂停前的数据。

如果要获取录音时候的一些参数,需要设置meteringEnabled参数为YES。
启动一个计时器NSTimer,并在每次轮询的时候更新录音参数。

- (void)handleRecorderData {
[_recorder updateMeters];
float peak0 = ([_recorder peakPowerForChannel:0] + 160.0) * (1.0 / 160.0);
float peak1 = ([_recorder peakPowerForChannel:1] + 160.0) * (1.0 / 160.0);
float ave0 = ([_recorder averagePowerForChannel:0] + 160.0) * (1.0 / 160.0);
float ave1 = ([_recorder averagePowerForChannel:1] + 160.0) * (1.0 / 160.0);
}

peakPowerForChannel:方法返回峰值
averagePowerForChannel:返回平均值
两个值的范围都是-160~0.

录音结束后的处理

AVAudioRecorderDelegate代理方法可以进行录音完成后的处理

- (void)audioRecorderDidFinishRecording:(AVAudioRecorder *)recorder successfully:(BOOL)flag {
if (flag) {
// 录音正常结束
} else {
// 未正常结束
if ([_recorder deleteRecording]) {
// 录音文件删除成功
} else {
// 录音文件删除失败
}
}
}

在调用这个代理的时候,录音已经结束了,所以无法从currentTime中获取到当前录音的时长。
想要获得总时长,可以用AVAudioPlayer加载,我的做法是在轮询时候进行取值,并作为成员变量记录。
换句话说,就是利用在播放期间访问recorder.currentTime并及时更新和记录。

录音结束后一些常用的信息:
录音文件地址:recorder.url.path
(笔者之前犯了一个常识性的错误,就是使用recorder.url.absoluteString获取路径,并用NSFileManager通过这个路径获得文件属性以求得文件大小,结果一直提示no such file,后来对比路径的时候发现absoluteString是带有url协议头的,所以提示大家一定要用url.path。)
录音文件大小[[NSFileManager defaultManager] attributesOfItemAtPath:recorder.url.path error:nil][NSFileSize];
有兴趣的同学可以打印一下attributesOfItemAtPath:error:方法返回的字典。

至此整个录音过程结束。

附录1 录音参数设置
官方文档:AV Foundation Audio Settings Constants

AVNumberOfChannelsKey:声道数 1、2
AVSampleRateKey:采样率 单位是Hz 常见值 44100 48000 96000 192000
AVLinearPCMBitDepthKey:比特率 8 16 32
AVEncoderAudioQualityKey 声音质量 需要的参数是一个枚举:
AVAudioQualityMin 最小的质量
AVAudioQualityLow 比较低的质量
AVAudioQualityMedium 中间的质量
AVAudioQualityHigh 高的质量
AVAudioQualityMax 最好的质量
AVEncoderBitRateKey:音频的编码比特率 BPS传输速率 一般为128000bps

附录2 借鉴文章来源
iOS开发系列–音频播放、录音、视频播放、拍照、视频录制
关于iPhone音频的那些事
iOS之录音


推荐阅读
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • dotnet 通过 Elmish.WPF 使用 F# 编写 WPF 应用
    本文来安利大家一个有趣而且强大的库,通过F#和C#混合编程编写WPF应用,可以在WPF中使用到F#强大的数据处理能力在GitHub上完全开源Elmis ... [详细]
  • 解决FCKeditor应用主题后上传问题及优化配置
    本文介绍了在Freetextbox收费后选择FCKeditor作为替代方案时遇到的上传问题及其解决方案。通过调整配置文件和调试工具,最终解决了上传失败的问题,并对相关配置进行了优化。 ... [详细]
  • 深入理解 .NET 中的中间件
    中间件是插入到应用程序请求处理管道中的组件,用于处理传入的HTTP请求和响应。它在ASP.NET Core中扮演着至关重要的角色,能够灵活地扩展和自定义应用程序的行为。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • andr ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • Struts与Spring框架的集成指南
    本文详细介绍了如何将Struts和Spring两个流行的Java Web开发框架进行整合,涵盖从环境配置到代码实现的具体步骤。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 本文介绍如何使用JPA Criteria API创建带有多个可选参数的动态查询方法。当某些参数为空时,这些参数不会影响最终查询结果。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
author-avatar
手机用户2502940341
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有