iOS学习记录之-AvAudioPlayer
前言:这两天老师布置了一个作业,编写一个音乐播放器的程序,使用AvAudioPlayer类。
AvAudioPlayer类是编写iOS播放器的三个类之一,其他两个以后用到再阐述。今天的主角是AvAudioPlayer。下面我们来一起看看这个类
首先介绍一下,AvAudioPlayer它是苹果公司封装好的一个类,用起来很方便,功能也很强大,但是它只支持播放沙盒存好的音乐,不支持在线播放,是苹果公司自家ipod
播放器专用的。这点大家知道即可不必深究;
好,言归正传:
1,创建AvAudioPlayer:
(1) 在工程中导入(AVFoundation.framework)框架,它是首要的,否则一切免谈,然后导入(#import <AVFoundation/AVFoundation.h>)这个头文件。
(2) 开始创建AvAudioPlayer
//这段代码是用来读取沙盒内歌曲用的
NSURL *soundFlieUrl = [[NSBundlemainBundle] URLForResource: _songsDatas[_index] withExtension:@"mp3"];
//创建一个错误对象,由于API接口要求的参数是传出参数,并且是指针的指针,所以在这里定义为指针对象
NSError *error = nil;
//创建AvAudioPlayer
AvAudioPlayer *avAudioPlayer = [[AVAudioPlayeralloc]initWithContentsOfURL:_soundFlieUrl error:&error];
[avAudioPlayer play];
至此我们的播放器就可以唱歌了。但如果想要功能更强大还需要设置AvAudioPlayer的诸多属性。
AvAudioPlayer属性一览:
@property(readonly, getter=isPlaying) BOOL playing;用来表示是否是播放状态
- (BOOL)prepareToPlay;准备播放
- (BOOL)play;播放
- (BOOL)playAtTime:(NSTimeInterval)time; 表示歌曲在这个时间开始播放
@property(readonly) NSUInteger numberOfChannels; 音频播放器所对应音频声道数量
@property(readonly) NSTimeInterval duration;表示曲目的总时长
@property(readonly) NSURL *url;获取创建数据的为本地的URL,如果不是通过本地URL创建,取值为nil
@property(readonly) NSData *data;获取创建的数据源为data,如果不是通过data传数据,取值为nil
@property float pan ;立体声的声道,-1是左声道,0是立体声,1是右声道
@property float volume; 音频音量 0-1之间
@property BOOL enableRate ;指定一个音频播放器调节是否可用,要想调节一个播放器速度,设置这个属性为YES,调用时机在初始化音频后和调用prepareToPlay函数前
@property float rate;音频播放速度,这个属性默认值是1.0,提供正常播放速度,0.5为速度一半,2.0为两倍速度,该值区域为0.5~2.0之间。该值起不起作用,受到enableRate影响。
@property NSTimeInterval currentTime;
音频播放所对应音频在时间线上的当前播放点。如果音频正在播放,currentTime被设置为当前播放位置到音频开始处的秒数。如果音频没有播放,currentTime被设置,play函数被调用是音频播放处到音频开始处的秒数。通过设置这个属性,你可以指定音频的特定点,后实现音频的快进后快回。
@property(readonly) NSTimeInterval deviceCurrentTime;
音频输出设备的时间值,单位秒。这个属性的值在音频播放或停止时都会单调递增。如果多个音频播放器连接到音频播放设置,设备时间会一直增加,只要有一个音频播放器处在播放或暂停状态。否则设备时间归0。使用这个属性去象征now,当调用playAtTime:函数时。通过配置多个音频播放器去播放在指定deviceCurrentTime的指定点,你可以实现精确的同步性。
@property NSInteger numberOfLoops;
设置音频循环次数。0是默认值,音频播放一次。设置一个正整数,指定播放次数正整数+1,设置一个负数,则无限循环播放,直到调用stop函数停止播放。
@property(readonly) NSDictionary *settings ;
音频播放器的设置字段,包括音频和所联系的播放器信息。
@property(getter=isMeteringEnabled) BOOL meteringEnabled;
设置计量器是否可用,默认是关闭的。
初始化方法
- (id)initWithContentsOfURL:(NSURL *)url error:(NSError **)outError;
初始化返回一个播放器,播放数据源为url。
- (id)initWithData:(NSData *)data error:(NSError **)outError;
初始化返回一个播放器,播放数据源为data。
2.- (BOOL)prepareToPlay;
判断是否准备好音频文件,用音频播放器进行播放。
3.- (BOOL)play;
打开音频播放器。
4.- (BOOL)playAtTime:(NSTimeInterval)time ;
在过多少时间将要打开音频播放器。
5.- (void)pause;
暂停音频播放器。
6.- (void)stop;
停止音频播放器,必须把currentTime设置为0,音频播放器才会恢复到起始状态。
7.- (void)updateMeters;
更新仪表读数
8.- (float)peakPowerForChannel:(NSUInteger)channelNumber;
- (float)averagePowerForChannel:(NSUInteger)channelNumber;
读取每个声道平均电平和峰值电平,代表每个声道的分贝数,范围在-100~0之间。
代理:
1.- (void)audioPlayerDidFinishPlaying:(AVAudioPlayer *)player successfully:(BOOL)flag;
当音频播放完回调。
2.- (void)audioPlayerDecodeErrorDidOccur:(AVAudioPlayer *)player error:(NSError*)error;
解码错误回调。
3.- (void)audioPlayerBeginInterruption:(AVAudioPlayer *)player;
处理中断回调。
出现例子:当用户在音频回放期间受到电话时,音频会消失,出现这种情况时AVAudioPlayer委托接受audioPlayerBeginInterruption:回调,音频会话暂时无效,并且暂停播放器。如果用户接听电话,那么应用程序中止,而应用程序委托接受一个applicationWillResignActive:回调。当通话结束,应用程序重新启动(利用applicationDidBecomeActive:回调)。如果用户拒绝接听电话那么将向委托发送audioPlayerBeginInterruption:回调。可以从此方法回复回放。
4.- (void)audioPlayerEndInterruption:(AVAudioPlayer *)player withOptions:(NSUInteger)flags ;
- (void)audioPlayerEndInterruption:(AVAudioPlayer *)player withFlags:(NSUInteger)flags;
- (void)audioPlayerEndInterruption:(AVAudioPlayer *)player;
处理中断结束回调。这里随着iOS系统更新,调用方法不同。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。