Автоматически начать запись звука, когда пользователь говорит - PullRequest
0 голосов
/ 16 мая 2018

Я пытаюсь начать запись, когда пользователь начинает говорить, и останавливает запись, когда пользователь заканчивает говорить.И я хочу ограничить максимальную длину аудио записи. Я не смог найти достаточно функций в AVAudioRecorderDelegate. Надеюсь, вы понимаете мою проблему. Заранее спасибо

@IBAction func recordAudio(_ sender: Any) {
    recordingLabel.text = "Recording in progress..."
    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()
}

@IBAction func stopRecording(_ sender: Any) {
    recordButton.isEnabled = true
    stopRecordingButton.isEnabled = false
    recordingLabel.text = "Tap to record..."

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

func audioRecorderDidFinishRecording(_ recorder: AVAudioRecorder, successfully flag: Bool) {
    if (flag) {
        //Success
    } else {
        print("Could not save audio recording!")
    }
}

1 Ответ

0 голосов
/ 16 мая 2018

Для записи аудио Когда пользователь tak1, вам нужно выполнить несколько шагов

1.Разрешение от пользователя на все ваше приложение использовать Mic

В вашем Info Plist Добавить Privacy - Microphone Usage Description в пользовательский Plist и добавить текстовое описание

2,Место для сохранения записанного файла пользователь FileManager

3.Чтобы закончить через время : используйте audioRecorder.record(forDuration: 30) // record for 30 Sec

Проверьте полный код:

import UIKit
import AVFoundation

class ViewController: UIViewController  {

   @IBOutlet weak var recordButton: UIButton!
    var recordingSession: AVAudioSession!
    var audioRecorder: AVAudioRecorder!


    override func viewDidLoad() {
        super.viewDidLoad()

    }

    @IBAction func recordAudio(_ sender: Any) {
        self.requestRecordPermission()
    }

    func requestRecordPermission() {
        recordingSession = AVAudioSession.sharedInstance()
        do {
            try recordingSession.setCategory(AVAudioSessionCategoryPlayAndRecord)
            try recordingSession.setActive(true)
            recordingSession.requestRecordPermission() { [unowned self] allowed in
                DispatchQueue.main.async {
                    if allowed {
                        // User allow you to record

                        // Start recording and change UIbutton color
                        self.recordButton.backgroundColor = .red
                        self.startRecording()

                    } else {
                        // failed to record!
                    }
                }
            }
        } catch {
            // failed to record!
        }
    }
    func startRecording() {

        let audioFilename = getDocumentsDirectory().appendingPathComponent("recordedFile.m4a")

        let settings = [
            AVFormatIDKey: Int(kAudioFormatMPEG4AAC),
            AVSampleRateKey: 12000,
            AVNumberOfChannelsKey: 1,
            AVEncoderAudioQualityKey: AVAudioQuality.high.rawValue
        ]

        do {
            audioRecorder = try AVAudioRecorder(url: audioFilename, settings: settings)
            audioRecorder.delegate = self
            audioRecorder.record(forDuration: 30)  // record for 30 Sec
            recordButton.setTitle("Tap to Stop", for: .normal)
            recordButton.backgroundColor = .green

        } catch {
            finishRecording(success: false)
        }
    }
    func getDocumentsDirectory() -> URL {
        let paths = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask)
        return paths[0]
    }

    @objc func recordTapped() {
        if audioRecorder == nil {
            startRecording()
        } else {
            finishRecording(success: true)
        }
    }

    public func finishRecording(success: Bool) {
        audioRecorder.stop()
        audioRecorder = nil

        if success {
            // record sucess
            recordButton.backgroundColor = .green
        } else {
            // record fail

            recordButton.backgroundColor = .yellow

        }
    }

}


extension ViewController :AVAudioRecorderDelegate{


    func audioRecorderDidFinishRecording(_ recorder: AVAudioRecorder, successfully flag: Bool) {
        if !flag {
            finishRecording(success: false)
        }
    }
}
...