大佬教程收集整理的这篇文章主要介绍了ios – Swift中的AudioUnitRender和ExtAudioFileWrite错误-50:尝试将MIDI转换为音频文件,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
现在我使用MIKMIDI作为一个工具来排序和播放MIDI文件,但它不包括将播放保存到文件中的功能. MIKMID的创建者概述了执行此操作的过程here.为了尝试捕获输出并将其保存到音频文件,我按照this example尝试用Swift中的GeneralIO节点替换MIKMIDI Graph的RemoteIO节点.当我尝试使用AudioUnitRender和ExtAudioFileWrite将输出保存到文件时,它们都返回错误-50(kAudio_ParamError).
var chAnnels = 2 var buffFrames = 512 var bufferList = AudioBufferList.allocate(maximumBuffers: 1) for i in 0...bufferList.count-1{ var buffer = AudioBuffer() buffer.mnumberChAnnels = 2 buffer.mDataByteSize = UInt32(buffFrames*sizeofValue(AudioUnitSampleTypE)) buffer.mData = calloc(buffFrames,sizeofValue(AudioUnitSampleTypE)) bufferList[i] = buffer result = AudioUnitRender(generalIOAudioUnit,&flags,&intimestamp,busNum,UInt32(buffFrames),bufferList.unsafeMutablePointer) intimestamp.mSampleTime += 1 result = ExtAudioFileWrite(extAudioFile,bufferList.unsafeMutablePointer) }
是什么导致错误-50,如何解决它以将MIDI(离线)渲染为.m4a文件?
更新:我通过将mnumberChAnnels和chAnnel更改为= 1来解决ExtAudioFileWrite错误-50.现在我得到一个带噪声的一秒音频文件. AudioUnitRender仍然返回错误-50.
>您的AudioBufferList不同意客户端格式,请尝试
let bufferList = AudioBufferList.allocate(maximumBuffers: Int(clientFormat.mChAnnelsPerFramE))
>您正在从AUGraph中替换错误的节点,并将剩余的节点连接到自身,导致AudioUnitRender上出现无限循环.
但主要的问题是你没有实现author suggested的解决方案.你希望你可以用实时时间戳调用AudioUnitRender,比实时更快,但作者说不,你必须手动将采样时间转换为主机时间并实现如果你想要的话,@L_276_4@midi球员的更好的部分.
所以你可以做到这一点(听起来很难)或者是file a feature request,或者通过在图形的远程IO音频单元中使用AudioUnitAddRenderNotify添加渲染通知并在kAudioUnitRenderAction_PostRender阶段写入样本来实时录制文件.
以上是大佬教程为你收集整理的ios – Swift中的AudioUnitRender和ExtAudioFileWrite错误-50:尝试将MIDI转换为音频文件全部内容,希望文章能够帮你解决ios – Swift中的AudioUnitRender和ExtAudioFileWrite错误-50:尝试将MIDI转换为音频文件所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。