Reproduzca audio de AVAudioPCMBuffer con AVAudioEngine

Tengo dos clasesMicrophoneHandleryAudioPlayer. He logrado usarAVCaptureSession tocar los datos del micrófono con la respuesta aprobadaaquí, y y convirtió elCMSampleBuffer aNSData usando esta función:

func sendDataToDelegate(buffer: CMSampleBuffer!)
{
    let block = CMSampleBufferGetDataBuffer(buffer)
    var length = 0
    var data: UnsafeMutablePointer<Int8> = nil

    var status = CMBlockBufferGetDataPointer(block!, 0, nil, &length, &data)    // TODO: check for errors

    let result = NSData(bytesNoCopy: data, length: length, freeWhenDone: false)

    self.delegate.handleBuffer(result)
}

Ahora me gustaría reproducir el audio a través del altavoz convirtiendo elNSData producido arriba paraAVAudioPCMBuffer y jugarlo usandoAVAudioEngine. MiAudioPlayerla clase es la siguiente:

var engine: AVAudioEngine!
var playerNode: AVAudioPlayerNode!
var mixer: AVAudioMixerNode!

override init()
{
    super.init()

    self.setup()
    self.start()
}

func handleBuffer(data: NSData)
{
    let newBuffer = self.toPCMBuffer(data)
    print(newBuffer)

    self.playerNode.scheduleBuffer(newBuffer, completionHandler: nil)
}

func setup()
{
    self.engine = AVAudioEngine()
    self.playerNode = AVAudioPlayerNode()

    self.engine.attachNode(self.playerNode)
    self.mixer = engine.mainMixerNode

    engine.connect(self.playerNode, to: self.mixer, format: self.mixer.outputFormatForBus(0))
}

func start()
{
    do {
        try self.engine.start()
    }
    catch {
        print("error couldn't start engine")
    }

    self.playerNode.play()
}

func toPCMBuffer(data: NSData) -> AVAudioPCMBuffer
{
    let audioFormat = AVAudioFormat(commonFormat: AVAudioCommonFormat.PCMFormatFloat32, sampleRate: 8000, channels: 2, interleaved: false)  // given NSData audio format
    let PCMBuffer = AVAudioPCMBuffer(PCMFormat: audioFormat, frameCapacity: UInt32(data.length) / audioFormat.streamDescription.memory.mBytesPerFrame)

    PCMBuffer.frameLength = PCMBuffer.frameCapacity

    let channels = UnsafeBufferPointer(start: PCMBuffer.floatChannelData, count: Int(PCMBuffer.format.channelCount))

    data.getBytes(UnsafeMutablePointer<Void>(channels[0]) , length: data.length)

    return PCMBuffer
}

El búfer alcanza elhandleBuffer:buffer funcionar cuandoself.delegate.handleBuffer(result) se llama en el primer fragmento de arriba.

soy capaz deprint(newBuffer), y vea las ubicaciones de memoria de los búferes convertidos, pero no sale nada de los altavoces. Solo puedo imaginar que algo no es consistente entre las conversiones hacia y desdeNSData. ¿Algunas ideas? Gracias por adelantado.

Respuestas a la pregunta(1)

Su respuesta a la pregunta