Свифт, AVAudioRecorder: Ошибка 317: ca_debug_string: inPropertyData == NULL - PullRequest
0 голосов
/ 05 сентября 2018

Я знаю, что есть потоки, в которых появляется это сообщение об ошибке, но они на самом деле не дают ответа на проблему, поэтому я решил открыть другой поток и спросить снова ... надеясь, что кто-то еще сталкивался с той же проблемой , решая это.

import UIKit
import AVFoundation

class RecordSoundsViewController: UIViewController, AVAudioRecorderDelegate {

// MARK: IBOutlets for Buttons
@IBOutlet weak var recordingLable: UILabel!
@IBOutlet weak var recordButton: UIButton!
@IBOutlet weak var stopRecordingButton: UIButton!

var audioRecorder : AVAudioRecorder!

override func viewDidLoad() {
    super.viewDidLoad()
    stopRecordingButton.isEnabled = false
    // Do any additional setup after loading the view, typically from a nib.
}

override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(animated)
}

@IBAction func recordAudio(_ sender: Any) {
    configureUI(true) // Call to set Buttons enabled state correct

    // MARK: AVAudio code and config....
    let dirPath = NSSearchPathForDirectoriesInDomains(.documentDirectory,.userDomainMask, true)[0] as String
    let recordingName = "recordedVoice.wav"
    let pathArray = [dirPath, recordingName]
    let filePath = URL(string: pathArray.joined(separator: "/"))

    let session = AVAudioSession.sharedInstance()
    try! session.setCategory(AVAudioSessionCategoryPlayAndRecord, with:AVAudioSessionCategoryOptions.defaultToSpeaker)

    try! audioRecorder = AVAudioRecorder(url: filePath!, settings: [:])
    audioRecorder.delegate = self
    audioRecorder.isMeteringEnabled = true
    audioRecorder.prepareToRecord()
    audioRecorder.record() //ca_debug_string Error occurs when this call is made.
}

// MARK: IBAction Stop Recording
@IBAction func stopRecording(_ sender: Any) {
    configureUI(false) // Call to set Buttons enabled state correct

    audioRecorder.stop()
    let audioSession = AVAudioSession.sharedInstance()
    try! audioSession.setActive(false)
}

// MARK: Func audioRecorderDidFinishRecording
func audioRecorderDidFinishRecording(_ recorder: AVAudioRecorder, successfully flag: Bool) {
    if flag {
        performSegue(withIdentifier: "stopRecording", sender: audioRecorder.url)
    } else {
        print("recording was not successful")
    }
}

// MARK: ConfigureUI Method for State of Buttons
func configureUI(_ recordingState: Bool) {
    if recordingState {
        recordingLable.text = "Recording in progress"
        stopRecordingButton.isEnabled = true
        recordButton.isEnabled = false
    } else {
        recordingLable.text = "Tap to record"
        stopRecordingButton.isEnabled = false
        recordButton.isEnabled = true
    }
}

// MARK: Prepare Viewcontroller
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
    if segue.identifier == "stopRecording" {
        let playSoundsVC = segue.destination as! PlaySoundsViewController //forced upcase
        let recordedAudioURL = sender as! URL
        playSoundsVC.recordedAudioURL = recordedAudioURL
        }
    }

}

Строка, в которой происходит ошибка:

audioRecorder.record()

Программа не прерывается и не падает (в симуляторе). Запись работает нормально, только это сообщение появляется в отладчике.

Если у кого-то есть идея, что может быть причиной проблемы, было бы очень признательно, если бы вы поделились этим здесь. Большое спасибо!

1 Ответ

0 голосов
/ 09 ноября 2018

Ваш session.setCategory устарел и должен быть переименован:

Неправильно:

try! session.setCategory(AVAudioSessionCategoryPlayAndRecord, with:AVAudioSessionCategoryOptions.defaultToSpeaker)

Правильно:

try! session.setCategory(AVAudioSession.Category.playAndRecord, mode: AVAudioSession.Mode.default, options: AVAudioSession.CategoryOptions.defaultToSpeaker)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...