我正在尝试将.m4a格式的给定音频文件转换为.aiff格式,使用 this post的答案.我已将代码转换为Swift 3.0.
func convertAudio(_ url: URL,outputURL: URL) {
    var error : Osstatus = noErr
    var destinationFile : ExtAudioFileRef? = nil
    var sourceFile : ExtAudioFileRef? = nil

    var srcFormat : AudioStreamBasicDescription = AudioStreamBasicDescription()
    var dstFormat : AudioStreamBasicDescription = AudioStreamBasicDescription()

    var audioConverter : AudioConverterRef? = nil

    ExtAudioFileOpenURL(url as CFURL,&sourceFile)

    var thePropertySize: UInt32 = UInt32(MemoryLayout.stride(ofValue: srcFormat))

    ExtAudioFileGetProperty(sourceFile!,kExtAudioFileProperty_FileDataFormat,&thePropertySize,&srcFormat)

    dstFormat.mSampleRate = 44100  //Set sample rate
    dstFormat.mFormatID = kAudioFormatLinearPCM
    dstFormat.mChannelsPerFrame = 1
    dstFormat.mBitsPerChannel = 16
    dstFormat.mBytesPerPacket = 2 * dstFormat.mChannelsPerFrame
    dstFormat.mBytesPerFrame = 2 * dstFormat.mChannelsPerFrame
    dstFormat.mFramesPerPacket = 1
    dstFormat.mFormatFlags = kAudioFormatFlagIsBigEndian | kAudioFormatFlagIsSignedInteger

    //Create destination file
    ExtAudioFileCreateWithURL(outputURL as CFURL,kAudioFileaifFType,&dstFormat,nil,AudioFileFlags.eraseFile.rawValue,&destinationFile)

    ExtAudioFileSetProperty(sourceFile!,kExtAudioFileProperty_ClientDataFormat,thePropertySize,&dstFormat)
    ExtAudioFileSetProperty(destinationFile!,&dstFormat)

    var size : UInt32 = UInt32(MemoryLayout.stride(ofValue: audioConverter))

    ExtAudioFileGetProperty(destinationFile!,kExtAudioFileProperty_AudioConverter,&size,&audioConverter)

    var canResume : UInt32 = 0

    size = UInt32(MemoryLayout.stride(ofValue: canResume))

    error = AudioConverterGetProperty(audioConverter!,kAudioConverterPropertyCanResumeFromInterruption,&canResume)

    let bufferByteSize : UInt32 = 32768
    var srcBuffer = [UInt8](repeating: 0,count: 32768)
    var sourceFrameOffset : ULONG = 0

    print("Converting audio file")

    while(true){

        var fillBufList = audiobufferlist(
            mNumberBuffers: 1,mBuffers: AudioBuffer(
                mNumberChannels: 2,mDataByteSize: UInt32(srcBuffer.count),mData: &srcBuffer
            )
        )
        var numFrames : UInt32 = 0

        if(dstFormat.mBytesPerFrame > 0){
            numFrames = bufferByteSize / dstFormat.mBytesPerFrame
        }

        ExtAudioFileRead(sourceFile!,&numFrames,&fillBufList)

        if(numFrames == 0){
            error = noErr;
            break;
        }

        sourceFrameOffset += numFrames
        error = ExtAudioFileWrite(destinationFile!,numFrames,&fillBufList)
    }

    ExtAudioFiledispose(destinationFile!)
    ExtAudioFiledispose(sourceFile!)
}

问题是audioConverter似乎在这一行是零

error = AudioConverterGetProperty(audioConverter!,&canResume)

而我似乎无法弄清楚为什么.我错过了什么?

跳过AudioConverterGetProperty

你实际上没有使用它.
以下代码片段将音频文件转换为aifF:它以一种支持的格式读取sourceFile,创建aifF编码器,并使用bufferByteSize缓冲区循环它.错误处理得当.

完整代码,swift 3:

func convertAudio(_ url: URL,outputURL: URL) {
    var error : Osstatus = noErr
    var destinationFile : ExtAudioFileRef? = nil
    var sourceFile : ExtAudioFileRef? = nil

    var srcFormat : AudioStreamBasicDescription = AudioStreamBasicDescription()
    var dstFormat : AudioStreamBasicDescription = AudioStreamBasicDescription()

    ExtAudioFileOpenURL(url as CFURL,&srcFormat)

    dstFormat.mSampleRate = 44100  //Set sample rate
    dstFormat.mFormatID = kAudioFormatLinearPCM
    dstFormat.mChannelsPerFrame = 1
    dstFormat.mBitsPerChannel = 16
    dstFormat.mBytesPerPacket = 2 * dstFormat.mChannelsPerFrame
    dstFormat.mBytesPerFrame = 2 * dstFormat.mChannelsPerFrame
    dstFormat.mFramesPerPacket = 1
    dstFormat.mFormatFlags = kAudioFormatFlagIsBigEndian |
                             kAudioFormatFlagIsSignedInteger

    // Create destination file
    error = ExtAudioFileCreateWithURL(
        outputURL as CFURL,&destinationFile)
    reportError(error: error)

    error = ExtAudioFileSetProperty(sourceFile!,&dstFormat)
    reportError(error: error)

    error = ExtAudioFileSetProperty(destinationFile!,&dstFormat)
    reportError(error: error)

    let bufferByteSize : UInt32 = 32768
    var srcBuffer = [UInt8](repeating: 0,count: 32768)
    var sourceFrameOffset : ULONG = 0

    while(true){
        var fillBufList = audiobufferlist(
            mNumberBuffers: 1,mData: &srcBuffer
            )
        )
        var numFrames : UInt32 = 0

        if(dstFormat.mBytesPerFrame > 0){
            numFrames = bufferByteSize / dstFormat.mBytesPerFrame
        }

        error = ExtAudioFileRead(sourceFile!,&fillBufList)
        reportError(error: error)

        if(numFrames == 0){
            error = noErr;
            break;
        }

        sourceFrameOffset += numFrames
        error = ExtAudioFileWrite(destinationFile!,&fillBufList)
        reportError(error: error)
    }

    error = ExtAudioFiledispose(destinationFile!)
    reportError(error: error)
    error = ExtAudioFiledispose(sourceFile!)
    reportError(error: error)
}

支持方式:

func reportError(error: Osstatus) {
    // Handle error
}

调用:

let sourceUrl = URL(string: Bundle.main.path(forResource: "sample",ofType: "mp3")!)
let paths = NSSearchPathForDirectoriesInDomains(.documentDirectory,.userDomainMask,true)
let documentsDirectory = URL(string: paths.first!)
let destUrl = documentsDirectory?.appendingPathComponent("converted.aiff")
if let sourceUrl = sourceUrl,let destUrl = destUrl {
    print("from \(sourceUrl.absoluteString) to \(destUrl.absoluteString)")
    convertAudio(sourceUrl,outputURL: destUrl)
}

使用AudioConverter Swift将.m4a文件转换为.aiff的更多相关文章

  1. 使用AudioConverter Swift将.m4a文件转换为.aiff

    我正在尝试将.m4a格式的给定音频文件转换为.aiff格式,使用thispost的答案.我已将代码转换为Swift3.0.问题是audioConverter似乎在这一行是零而我似乎无法弄清楚为什么.我错过了什么?

  2. swift – 如何以编程方式撰写邮件?

    如何在撰写屏幕上打开“消息”应用程序,并在消息正文中预先加载特定文本?)这导致NSURL初始化返回nil,因为URL字符串格式错误.这是一个有条理地解开选项的工作示例.这消除了与强制解包的nil选项相关的任何崩溃的可能性.

  3. Yii2如何将HTML锚标记映射到yii2 html :: a()标记

    嗨,大家好我正在学习yii2我的一个基于产品的webapp.我正在将现有代码转换为yii2HTML代码格式&在转换以下内容时遇到问题:帮助我们,如果有人有解决方案的上述??????除了阿里的回答是完全有效的,你也可以写

  4. Ajax Zero to Hero (2)入门代码的简单封装

    注意:

  5. 去哪里PHP parse_url()不 – 只解析域

    有没有人知道这种事情的预先有效的REGEX?这样的东西怎么样?

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部