多媒体之音乐播放

简介:

音效是比较简短的,音乐比较长,格式比较多,那就需要使用<AVFoundation/AVFoundation.h>框架,AVAudioPlayer只支持本地的


//
//  ViewController.m
//  AVFoundation
//
//  Created by City--Online on 15/5/5.
//  Copyright (c) 2015年 CYW. All rights reserved.
//
 
#import "ViewController.h"
#import <AVFoundation/AVFoundation.h>
 
@interface ViewController ()<AVAudioPlayerDelegate>
@property(nonatomic,strong)AVAudioPlayer *audioPlayer;
@property(nonatomic,strong)UIButton *btnStop;
@property(nonatomic,strong)UIButton *btnPause;
@property(nonatomic,strong) UIButton *btnPlayer;
@property(nonatomic,strong)UIProgressView *progress;
@property(nonatomic,strong)UIProgressView *averagePowerProgress;
@property(nonatomic,weak)NSTimer *timer;
 
@end
 
@implementation ViewController
 
- (void)viewDidLoad {
    [super viewDidLoad];
    [self stepUI];
     
    NSString *path=[[NSBundle mainBundle]pathForResource:@"1" ofType:@".mp3"];
    NSURL *url=[[NSURL alloc]initFileURLWithPath:path];
    _audioPlayer=[[AVAudioPlayer alloc]initWithContentsOfURL:url error:nil];
    //立体声平衡 -1 左声道  0 左右声道平衡  1右声道
    _audioPlayer.pan=1.0;
    //音量(0-1)
    _audioPlayer.volume=0.8;
    //是否允许改变速率
    _audioPlayer.enableRate=YES;
    //播放速率 (0.5-2) 1.0正常播放
    _audioPlayer.rate=0.8;
    //是否启用音频测量 默认NO
    _audioPlayer.meteringEnabled=true;
    //循环次数
    _audioPlayer.numberOfLoops=3;
    //设置代理
    _audioPlayer.delegate=self;
     
     
}
-(void)stepUI
{
    // 进度条
   _progress=[[UIProgressView alloc]initWithFrame:CGRectMake(100, 100, 200, 10)];
    [self.view addSubview:_progress];
     
    _averagePowerProgress=[[UIProgressView alloc]initWithFrame:CGRectMake(100,  200, 100, 10)];
    [self.view addSubview:_averagePowerProgress];
     
    //停止播放
    _btnStop=[UIButton buttonWithType:UIButtonTypeSystem];
    [_btnStop setTitle:@"停止" forState:UIControlStateNormal];
    _btnStop.frame=CGRectMake(40, 150, 40, 40);
    _btnStop.tag=1001;
    [_btnStop addTarget:self action:@selector(operation:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:_btnStop];
     
    //播放
    _btnPlayer=[UIButton buttonWithType:UIButtonTypeSystem];
    [_btnPlayer setTitle:@"播放" forState:UIControlStateNormal];
    _btnPlayer.frame=CGRectMake(90, 150, 40, 40);
    _btnPlayer.tag=1002;
    [_btnPlayer addTarget:self action:@selector(operation:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:_btnPlayer];
     
    _btnPause=[UIButton buttonWithType:UIButtonTypeSystem];
    [_btnPause setTitle:@"暂停" forState:UIControlStateNormal];
    _btnPause.frame=CGRectMake(140, 150, 40, 40);
    _btnPause.tag=1003;
    [_btnPause addTarget:self action:@selector(operation:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:_btnPause];
     
    _timer=[NSTimer scheduledTimerWithTimeInterval:0.2 target:self selector:@selector(updateProgress) userInfo:nil repeats:YES];
   
}
-(void)operation:(id)sender
{
    UIButton *btn=(UIButton *)sender;
    switch (btn.tag) {
        case 1001:
            if ([_audioPlayer isPlaying]) {
                [_audioPlayer stop];
                [_progress setProgress:0];
                //
                 _timer.fireDate=[NSDate distantFuture];
                _audioPlayer.currentTime=0;
                 
                NSLog(@"%ld",_audioPlayer.numberOfChannels);
            }
            break;
        case 1002:
            if (![_audioPlayer isPlaying]) {
                [_audioPlayer play];
                //恢复定时
                _timer.fireDate=[NSDate distantPast];
            }
            break;
        case 1003:
            if ([_audioPlayer isPlaying]) {
                [_audioPlayer pause];
                //暂停定时器,注意不能调用invalidate方法,此方法会取消,之后无法恢复
                _timer.fireDate=[NSDate distantFuture];
            }
            break;
 
        default:
            break;
    }
     
 
}
-(void)updateProgress
{
    float progress=_audioPlayer.currentTime/_audioPlayer.duration;
    [_progress setProgress:progress animated:YES];
    //更新音频测量值,注意如果要更新音频测量值必须设置meteringEnabled为YES,通过音频测量值可以即时获得音频分贝等信息
    [_audioPlayer updateMeters];
    //获得指定声道的分贝峰值,注意如果要获得分贝峰值必须在此之前调用updateMeters方法
//   float  peakPower=[_audioPlayer peakPowerForChannel:2];
//    NSLog(@"%lf",peakPower);
    //获得指定声道的分贝平均值,注意如果要获得分贝平均值必须在此之前调用updateMeters方法
   float averagePower= [_audioPlayer averagePowerForChannel:1];
    //类似上下波动
    [_averagePowerProgress setProgress:(-averagePower)/50.0 animated:YES];
    NSLog(@"%lf",averagePower);
     
}
 
 
-(void)dealloc{
    [[NSNotificationCenter defaultCenter] removeObserver:self name:AVAudioSessionRouteChangeNotification object:nil];
}
- (void)audioPlayerDidFinishPlaying:(AVAudioPlayer *)player successfully:(BOOL)flag;
{
    NSLog(@"播放完毕");
}
 
 
- (void)audioPlayerDecodeErrorDidOccur:(AVAudioPlayer *)player error:(NSError *)error
{
     NSLog(@"%@",error);
}
- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}
 
@end

 

上面的是进度条,下面的是分贝平均值,类似有的音乐播放器波浪效果

相关文章
|
6月前
音视频播放器
音视频播放器
|
7月前
|
小程序 JavaScript 前端开发
微信小程序的音频视屏播放
微信小程序的音频视屏播放
128 0
HMI-55-【多媒体】音乐播放器 4
今天我们接着搞音乐播放器,今天主要实现音乐播放器的播放音频功能
HMI-52-【多媒体】音乐播放器 1
今天我们搞音乐播放器,哎嗨,这个东西要是往细碎了搞,事情还真不少,今天就先努力实现面上的内容。
HMI-56-【多媒体】音乐播放器 5
上一篇中实现了音乐播放的后台线程,夜里睡觉也没有睡踏实,总是感觉不合适,所以今天还是决定重新搞一下。
HMI-53-【多媒体】音乐播放器 2
今天我们接着搞我们的音乐播放器,今天我把们昨天剩下的那些布局搞一搞,后面再实现细节,今天我们把下面的菜单和逻辑实现了,以及上次漏掉的右上角的子菜单按钮。
HMI-54-【多媒体】音乐播放器 3
今天我们接着搞音乐播放器,今天我们实现这个中心的音乐播放器。也就是这个歌曲信息,上一曲下一曲暂停,播放进度啥的。
|
存储 编解码 缓存
带你走进多媒体世界:视频文件是怎么播放出来的
本文将聚焦在说明多媒体世界中的视频文件是怎么播放出来的。一个多媒体文件播放涉及到哪些过程?人体通过肉眼看到画面、通过耳朵听到视频声音,这中间经过了哪些处理?本文将尽可能通过简单易懂的文字讲述一个视频文件的播放流程。
带你走进多媒体世界:视频文件是怎么播放出来的