我是 IOS 开发的新手。我正在尝试使用 AVAudioRecorder 在后台录制用户语音,但我将“音频”添加到 UIBackgroundModes 但这没有帮助。顺便说一句,一切都在前台运行完美。当在后台时,计时器工作正常,但没有录音。如何从背景的麦克风录制?这可能吗?
3 回答
你可以。Skype 做到了这一点。
您可能需要<key>UIBackgroundModes</key><array><string>audio</string></array>
在 Info.plist 中进行设置,并且您需要确保在切换应用程序之前音频会话处于活动状态/正在运行/无论何时(假设您不会突然开始录制/播放音乐/无论何时您的应用程序在后台)。
文档说“音频”可以让你在后台播放音频,但大概这也适用于录制音频。如果它不起作用,您可以尝试以下几种方法:
- 设置“voip”和“audio”。
- 播放静音(这可能是使用音频队列 API 最容易做到的)。
此材料来自此处:音频录制应用程序的 iOS 多任务处理
额外的材料看到这个:只要我按下“HOME”按钮,他就会停止录制 构建背景感知应用程序
您需要UIBackgroundModes
在应用程序 plist 文件中设置为音频。
是的,当应用程序在后台运行时,可以同时录制和播放。首先,您需要为您的应用启用后台模式,使用以下步骤。
-- 在 Xcode 的 Navigator 中选择你的项目文件。然后,从 Capabilities 部分,打开 Background Modes 子部分。在为您提供背景模式列表后,勾选音频和 Airplay 开关。
-- 使用以下代码在应用程序的前台和后台状态下录制和播放音频。如果设备处于静音模式或用户锁定设备,下面的代码还会录制和播放音频。
import UIKit
import AVFoundation
extension String {
func stringByAppendingPathComponent(path: String) -> String {
let nsSt = self as NSString
return nsSt.stringByAppendingPathComponent(path)
}
}
class ViewController: UIViewController, AVAudioPlayerDelegate, AVAudioRecorderDelegate{
var audioPlayer : AVAudioPlayer!
var audioRecorder : AVAudioRecorder!
@IBOutlet var recordButton : UIButton!
@IBOutlet var playButton : UIButton!
@IBOutlet var stopButton : UIButton!
override func viewDidLoad() {
super.viewDidLoad()
self.recordButton.enabled = true
self.playButton.enabled = false
self.stopButton.enabled = false
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
//MARK: UIButton action methods
@IBAction func playButtonClicked(sender : AnyObject){
let dispatchQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0)
dispatch_async(dispatchQueue, {
if let data = NSData(contentsOfFile: self.audioFilePath())
{
do{
let session = AVAudioSession.sharedInstance()
try session.setCategory(AVAudioSessionCategoryPlayback)
try session.setActive(true)
self.audioPlayer = try AVAudioPlayer(data: data)
self.audioPlayer.delegate = self
self.audioPlayer.prepareToPlay()
self.audioPlayer.play()
}
catch{
print("\(error)")
}
}
});
}
@IBAction func stopButtonClicked(sender : AnyObject){
if let player = self.audioPlayer{
player.stop()
}
if let record = self.audioRecorder{
record.stop()
}
let session = AVAudioSession.sharedInstance()
do{
try session.setActive(false)
}
catch{
print("\(error)")
}
}
@IBAction func recordButtonClicked(sender : AnyObject){
let session = AVAudioSession.sharedInstance()
do{
try session.setCategory(AVAudioSessionCategoryPlayAndRecord)
try session.setActive(true)
session.requestRecordPermission({ (allowed : Bool) -> Void in
if allowed {
self.startRecording()
}
else{
print("We don't have request permission for recording.")
}
})
}
catch{
print("\(error)")
}
}
func startRecording(){
self.playButton.enabled = false
self.recordButton.enabled = false
self.stopButton.enabled = true
do{
let fileURL = NSURL(string: self.audioFilePath())!
self.audioRecorder = try AVAudioRecorder(URL: fileURL, settings: self.audioRecorderSettings() as! [String : AnyObject])
if let recorder = self.audioRecorder{
recorder.delegate = self
if recorder.record() && recorder.prepareToRecord(){
print("Audio recording started successfully")
}
}
}
catch{
print("\(error)")
}
}
func audioFilePath() -> String{
let path = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.UserDomainMask, true)[0]
let filePath = path.stringByAppendingPathComponent("test.caf") as String
//let filePath = NSBundle.mainBundle().pathForResource("mySong", ofType: "mp3")!
return filePath
}
func audioRecorderSettings() -> NSDictionary{
let settings = [AVFormatIDKey : NSNumber(int: Int32(kAudioFormatMPEG4AAC)), AVSampleRateKey : NSNumber(float: Float(16000.0)), AVNumberOfChannelsKey : NSNumber(int: 1), AVEncoderAudioQualityKey : NSNumber(int: Int32(AVAudioQuality.Medium.rawValue))]
return settings
}
//MARK: AVAudioPlayerDelegate methods
func audioPlayerDidFinishPlaying(player: AVAudioPlayer, successfully flag: Bool) {
if flag == true{
print("Player stops playing successfully")
}
else{
print("Player interrupted")
}
self.recordButton.enabled = true
self.playButton.enabled = false
self.stopButton.enabled = false
}
//MARK: AVAudioRecorderDelegate methods
func audioRecorderDidFinishRecording(recorder: AVAudioRecorder, successfully flag: Bool) {
if flag == true{
print("Recording stops successfully")
}
else{
print("Stopping recording failed")
}
self.playButton.enabled = true
self.recordButton.enabled = false
self.stopButton.enabled = false
}
}
只需复制此代码并将其粘贴到空视图控制器 swift 文件中,在 xib 文件或故事板文件中创建三个按钮“记录”、“停止”、“播放”,连接@IBOutlet 和@IBAction。在真实设备上测试此代码,因为您需要麦克风来录制音频。我已经针对 xCode 7 和 iOS 9 及其工作进行了测试。