AudioToolbox.framework框架

在开发直播APP的时候,用到了AudioToolbox.framework框架。。 在这里做一个总结,分享给大家

AudioFileStream类,提供了一个接口,用来解析一个流音频文件

创建一个 new stream parse

//aquire some data

AudioFileStreamParseBytes(<#AudioFileStreamID inAudioFileStream#>, <#UInt32 inDataByteSize#>, <#const void *inData#>, <#UInt32 inFlags#>);

//设置从流文件中读取data时的offset

AudioFileStreamSeek(<#AudioFileStreamID inAudioFileStream#>, <#SInt64 inPacketOffset#>, <#SInt64 *outDataByteOffset#>, <#UInt32 *ioFlags#>);

//获取完数据后,关闭该流对象

AudioFileClose(<#AudioFileID inAudioFile#>)

AudioServices

AudioQueue

使用一个缓冲队列来存储data,用来播放或录音。播放或录音的时候,数据以流的形式操作,可以边获取数据变播放,或者边录音,边存储。

-------------------------------------------------------------------------

NSFileHandle 用来从文件、socket中读取数据

CFReadStream 用来读取一个字节流byte stream,该字节流可以来自于内存、一个文件、一个socket。在读bytes之前,流stream需要被打开。

CFWriteStream用来写一个字节流

AudioQueueRef  定义的一个不透明的数据类型,专门用来代表一个audio queue

AudioQueueBufferRef 是AudioQueueBuffer的别名,表明该参数为一个AudioQueueBuffer对象

AudioFileID 定义一个不透明的数据类型,代表一个audiofile的对象

反思:以ref结尾的对象名称,一般是在参数中使用,表明这个参数的数据类型

//===============

AudioStreamBasicDescription

音频数据流格式的描述.Callback Method 回调函数,系统规定好了回调函数的参数,以及调用的地方,你只需要保证参数的格式正确,向函数里添加代码即可,函数的方法名称可以随便写,没有强制的规定。

AudioQueueNewOutput的第三个参数:inUserData 这是由用户来自定义的,数据的来源。只需要传递一个对象进去即可。使用,当系统自动调用回调函数MyAudioQueueOutputCallback或者MyAudioQueueInputCallback时候,返回的第一个参数inUserData就是你在AudioQueueNewOutput中设置的第三个参数。然后,你需要在回调函数中使用这个对象填充buffer(播放音频,当一个buffer为空时自动调用)或者读取buffer的数据(录音,当一个buffer满时自动调用)。

AudioFileStream_PropertyListenerProc

当在audio stream中找到一个property value后,回调该方法。

AudioFileStream_PacketsProc当在stream中找到audio data后回调该方法。

在参数中的in和out个代表的意思:in代表的是这个参数需要你在外面得到然后传递进去,在这个方法中要使用;out开头的参数表示这个参数是这个方法返回的值,你一般只需要定义一个引用,然后传递进去,执行完这个方法后,这个参数就实例化了。oh,my god!坑爹的苹果。

AudioFile类

一个c编程接口,使用AudioFile可以从内存或硬盘中读取或写入多种格式的音频数据。

AudioFileStream类

提供了一个借口,用来解析流音频文件。功能:从网络中读取数据流,把数据流解析成音频文件。

音频文件流是不容易获取的。当需要从stream中读取data时,以前的data可能已无法使用,而新的data还没有到达,而从网络中获取的data可能还包含packets数据。为了解析audio stream,parser必须记着已经获取的数据,等待剩余的数据。

缓冲区是在哪设置的?

AudioQueue类

一个c编程接口,是Core Audio的一部分。功能:录音、播放音频。

AudioQueue类播放音频时,在内存中维护着一个buffer queue。只要buffer中有数据就可以播放,因此,一般使用AudioQueue对象来播放音频流,这样可以“边下载边播放”。

播放音频的方法:

AudioQueueNewOutput

1、用来创建一个播放音频队列的对象AudioQueueRef,然后就是对该audioqueue对象进行操作。

2、用来添加一个回调方法AudioQueueOutputCallback,调用该方法时会返回一个audioqueue的buffer,该buffer中的数据已经被使用,需要在这个方法中填充新数据。

3、

AudioQueueEnqueueBuffer

想缓冲区中添加新的数据(数据一般从file或网络中获取)

//====下载=====

CFReadStream

CFReadStreamClientCallBack回调函数在CFReadStreamSetClient中调用,是第三个参数。CFReadStreamClientCallBack只有在满足CFReadStreamSetClient中添加的streamEvents发生时才会别回调。

CFReadStreamScheduleWithRunLoop方法把stream加到一个线程中。然后,CFReadStreamSetClient在设置的东西就起作用了。当各种streamEvent发生时,client都会得到通知,client判断是否执行回调方法CFReadStreamClientCallBack。

AudioSession类

一个c接口,用来管理应用中audio的行为。

线程的操作,暂停后可能是县城就停止了。

对线程的操作  让某一个线程停下来。

AudioQueue

一个c编程接口,是Core Audio的一部分。功能:录音、播放音频。

AudioQueue类播放音频时,在内存中维护着一个buffer queue。只要buffer中有数据就可以播放,因此,一般使用AudioQueue对象来播放音频流,这样可以“边下载边播放”。

audioqueue中的方法都是静态方法,使用时传递进去的参数前缀是in,传递出来的参数前缀是out播放音频的方法:

AudioQueueNewOutput

1、用来创建一个播放音频队列的对象AudioQueueRef,然后就是对该audioqueue对象进行操作。

2、用来添加一个回调方法AudioQueueOutputCallback,调用该方法时会返回一个audioqueue的buffer,该buffer中的数据已经被使用,需要在这个方法中填充新数据。

3、

AudioQueueEnqueueBuffer

想缓冲区中添加新的数据(数据一般从file或网络中获取)

AudioQueueAllocateBuffer

为一个audioqueue分配一个queueBuffer,每调用一次创建一个缓冲区,最后所有的缓冲区组成一个缓冲队列。

AudioQueueCreateTimeline

创建一个与audioqueue相关的时间轴。如果想要显示audio的时间,需要熟悉uyutimeLine相关的方法。

audioqueue的属性操作:

具体属性类型见官方文档:https://developer.apple.com/library/ios/#documentation/MusicAudio/Reference/AudioQueueReference/Reference/reference.html#//apple_ref/c/func/AudioQueueAddPropertyListener

AudioQueueSetProperty

用来设置某一个audioqueue对象的属性,具体属性以 kAudioQueueProperty_*开头

AudioQueueGetProperty

获取audioqueue对象的某一个属性值。首先应该先调用AudioQueueGetPropertySize方法获取value的大小(byte形式)

AudioQueueAddPropertyListener

添加一个属性监听器。当一个audioqueue的对应属性值改变时,会回调这个监听器。

audioqueue的参数操作:

AudioQueueSetParameter

AudioQueueGetParameter

对参数的修改和获取,具体参数parameter包括:音量的调节、声道的调节、以及音量的渐变设置

你可能感兴趣的:(AudioToolbox.framework框架)