AFSoundManager

iOS audio playing (both local and streaming) and recording made easy through a complete and block-driven Objective-C class. AFSoundManager uses AudioToolbox and AVFoundation frameworks to serve the audio. You can pick a local file or you can use a URL to stream the audio, the choice is up to you.

这是一个用block方式编写的简单易用的iOS音频播放(支持本地与流媒体方式)以及录制的类。AFSoundManager使用了AudioToolbox、AVFoundation框架来处理音频。你可以使用一个本地的文件,或者是一个网络上的URL流媒体音频,怎么用取决于你呢。

Installation

AFSoundManager is available on CocoaPods so you can get it by adding this line to your Podfile:

AFSoundManager支持CocoaPods,你可以添加以下一句话到Podfile中来使用:

pod 'AFSoundManager'

If you don't use CocoaPods, you will have to import these files into your project:

如果你不想使用CocoaPods,你可以导入以下几个头文件即可:

AFSoundManager.h
AFSoundManager.m
AFAudioRouter.h
AFAudioRouter.m

Also, you need to import the AudioToolbox framework and te AudioFoundation framework.

当然,你需要引入AudioToolbox与AudioFoundation框架。

Usage

First of all, make sure that you have imported the main class into the class where you are going to play audio.

首先,确保在你要使用的地方引入了以下头文件:

#import "AFSoundManager.h"

Then, you only need to call one method to start playing your audio.

然后,你只需要调用一个方法就可以播放音频了。

Local playing

If you need to play a local file, call -startPlayingLocalFileWithName:atPath:withCompletionBlock:. If you want to use the default path, just set it as nil.

如果你想播放以下本地的文件,调用-startPlayingLocalFileWithName:atPath:withCompletionBlock:方法,如果你想使用默认的路径,只需要将path设置成nil即可。

Example:

例如:

[[AFSoundManager sharedManager] startPlayingLocalFileWithName:@"filename.mp3" atPath:nil withCompletionBlock:^(int percentage, CGFloat elapsedTime, CGFloat timeRemaining, NSError *error) {

    if (!error)
//This block will be fired when the audio progress increases in 1%
} else {
//Handle the error
}
}];

Audio streaming

For remote audio, call -startStreamingRemoteAudioFromURL:andBlock:

如果要播放流媒体,调用-startStreamingRemoteAudioFromURL:andBlock:

Example:

例子:

[[AFSoundManager sharedManager] startStreamingRemoteAudioFromURL:@"http://www.example.com/audio/file.mp3" andBlock:^(int percentage, CGFloat elapsedTime, CGFloat timeRemaining, NSError *error) {

    if (!error)
//This block will be fired when the audio progress increases in 1%
} else {
//Handle the error
}
}];

Control

If you need to pause, resume or stop the current playing, guess what, there's a method for that!

如果你想要暂停,恢复或者停止当前播放的音频,猜猜怎么弄?用以下方法即可!

[[AFSoundManager sharedManager]pause];
[[AFSoundManager sharedManager]resume];
[[AFSoundManager sharedManager]stop];
[[AFSoundManager sharedManager]restart];

For going back or forward, you have to specify the second where to continue playing the audio by calling -moveToSecond:

如果要快进或者倒退,你需要指定在什么地方来继续播放,调用方法-moveToSecond:

For example, if you need to move the audio to the second 288, call

例如,你需要将音频快进到288s,调用

[[AFSoundManager sharedManager]moveToSecond:288];

If you are using a UISlider, for example, and you need to work with values between 0.000000 and 1.000000, don't you worry, we got it:

如果你想用一个UISlider,其取值范围是介于0.00000与1.00000之间,不用急,你可以这么用:

[[AFSoundManager sharedManager]moveToSection:0.345680]; //That will move the audio to the 34.568% of its total progress

You can also change the speed rate of the playing.

你也可以修改播放的速度。

[[AFSoundManager sharedManager]changeSpeedToRate:2.0];

The normal rate would be 1.0, while the half-speed playback would be 0.5 and the double speed playback 2.0

默认的播放速度是1.0,你也可以让播放速度变快(设置成2.0)或者是播放速度变慢(设置成0.5)

In order to change the volume, call -changeVolumeToValue: by passing a decimal number between 0.000000 (mute) and 1.000000 (maximum volume). Example:

修改音量的话,调用-changeVolumeToValue:,你传入的值介于0.00000-1.00000即可:

[[AFSoundManager sharedManager] changeVolumeToValue:0.750000]; //This will put the volume at 75%

Playing status

In order to get noticed of the playing status changes, you need to implement theAFSoundManagerDelegate by adding it to your class, just like other delegates.

为了获取到播放状态的变更,你需要实现theAFSoundManagerDelegate代理,就像使用其他代理方法一样。

Then, just implement the currentPlayingStatusChanged: method in the class you want to get notified about the status changes in.

然后,你只需要实现以下的方法currentPlayingStatusChanged:,在这个方法里面,你可以获取到状态值的变化。

-(void)currentPlayingStatusChanged:(AFSoundManagerStatus)status {

    switch (status) {

        case AFSoundManagerStatusFinished:
//Playing got finished
break; case AFSoundManagerStatusPaused:
//Playing was paused
break; case AFSoundManagerStatusPlaying:
//Playing got started or resumed
break; case AFSoundManagerStatusRestarted:
//Playing got restarted
break; case AFSoundManagerStatusStopped:
//Playing got stopped
break;
}
}

Handle the change in each case.

你可以在每种状态中获取到事件。

Background playing

If you want to enable background playing, make sure you have Background Modes enabled on your project, under the Capabilities section:

如果你想要支持后台播放,确保你已经开启了后台播放,请在Capabilities这个地方进行设置:

Also, add this information to your info.plist file:

然后,在你的info.plist文件中进行对应的设置:

Output manage

AFSoundManager also lets you choose which device do you want to use to play the audio. I mean, even if you have your headphones plugged in, you can force the audio to play on the built-in speakers or play it through the headphones.

AFSoundManager支持让你选择用什么设备来播放音频,我的意思是,即使你插入了耳机,你也可以强制用你的喇叭来播放音频:

If the headphones (or any external speaker) are plugged in and you want to play it on the built-in speakers, call:

如果耳机插入了(或者是其他外放设备),这时候你还是想用内置的喇叭,调用:

[[AFSoundManager sharedManager] forceOutputToBuiltInSpeakers];

If you want to play it through the default device (in this case the headphones or the external speaker) call

如果你想使用默认的设备(这种情况下的意思是外部设备),调用:

[[AFSoundManager sharedManager] forceOutputToDefaultDevice];

And if you want to check if the headphones, or a external speaker, are currently plugged in on the device, check it with -areHeadphonesConnected. Example:

如果你想检测一下这个当前外部设备时候已经插入进来,用这个方法来检测:

if ([[AFSoundManager sharedManager] areHeadphonesConnected]) {
//Headphones connected
} else {
//Headphones NOT connected
}

Recording audio

Start recording audio from the device's microphone is easy peasy!

从设备录音是非常简单的呢!

[[AFSoundManager sharedManager] startRecordingAudioWithFileName:@"recording" andExtension:@"mp3" shouldStopAtSecond:25];

If you don't want recording to stop automatically, set shouldStopAtSecond as 0 or nil.

如果你不想录音的时候自动停止,将shouldStopAtSecond设置成0或者nil。

Control the recording

AFSoundManager let's you perform several actions with your current recording:

AFSoundManager给你提供了几种方法来控制当前的音频录制:

AFSoundManager

[[AFSoundManager sharedManager] pauseRecording]; // Pauses the current recording
[[AFSoundManager sharedManager] resumeRecording]; // Resumes the current recording (if it's paused)
[[AFSoundManager sharedManager] stopAndSaveRecording]; // Stops the current recording and closes the file
[[AFSoundManager sharedManager] deleteRecording]; // Delete the current recording (perform this before stoping it)

Lastly, to get the current recording duration, call -timeRecorded which will return a NSTimeInterval object.

最后,如果要获取当前的录音的时间,调用-timeRecorded这个方法,他会给你返回NSTimeInterval的对象。

License

AFSoundManager is under MIT license so feel free to use it!

AFSoundManager支持MIT协议,所以,你可以免费的使用!

Author

Made by Alvaro Franco. If you have any question, feel free to drop me a line at alvarofrancoayala@gmail.com

作者是Alvaro Franco。有任何问题, 给我发邮件( alvarofrancoayala@gmail.com )吧。

[翻译] AFSoundManager的更多相关文章

  1. 《Django By Example》第五章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者@ucag注:大家好,我是新来的翻译, ...

  2. 《Django By Example》第四章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:祝大家新年快乐,这次带来<D ...

  3. [翻译]开发文档:android Bitmap的高效使用

    内容概述 本文内容来自开发文档"Traning > Displaying Bitmaps Efficiently",包括大尺寸Bitmap的高效加载,图片的异步加载和数据缓存 ...

  4. 【探索】机器指令翻译成 JavaScript

    前言 前些时候研究脚本混淆时,打算先学一些「程序流程」相关的概念.为了不因太枯燥而放弃,决定想一个有趣的案例,可以边探索边学. 于是想了一个话题:尝试将机器指令 1:1 翻译 成 JavaScript ...

  5. 《Django By Example》第三章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:第三章滚烫出炉,大家请不要吐槽文中 ...

  6. 《Django By Example》第二章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:翻译完第一章后,发现翻译第二章的速 ...

  7. 《Django By Example》第一章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:本人目前在杭州某家互联网公司工作, ...

  8. 【翻译】Awesome R资源大全中文版来了,全球最火的R工具包一网打尽,超过300+工具,还在等什么?

    0.前言 虽然很早就知道R被微软收购,也很早知道R在统计分析处理方面很强大,开始一直没有行动过...直到 直到12月初在微软技术大会,看到我软的工程师演示R的使用,我就震惊了,然后最近在网上到处了解和 ...

  9. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第一章:创建基本的MVC Web站点

    在这一章中,我们将学习如何使用基架快速搭建和运行一个简单的Microsoft ASP.NET MVC Web站点.在我们马上投入学习和编码之前,我们首先了解一些有关ASP.NET MVC和Entity ...

随机推荐

  1. Python——可变类型与不可变类型(即为什么函数默认参数要用元组而非列表)

    Python 的内建标准类型有一种分类标准是分为可变类型与不可变类型: 可变类型:列表.字典 不可变类型:数字.字符串.元组 因为变量保存的实际都是对象的引用,所以在给一个不可变类型(比如 int)的 ...

  2. sublime text3怎么让左侧显示目录树

    在前端开发中(包括Node.js开发),经常会使用sublime text,但之前一直不知道别人是怎么让左侧显示目录树,故特意在此记录一下. View ->Side Bar ->Show ...

  3. SharePoint 2013创建应用程序时IIS端口文件夹下没文件

    最近SharePoint 2007迁移到2013的时候,碰到创建应用程序时IIS端口文件夹下没文件的问题,网上找了大把的原因,终于在这里找到了解决方案: Fix: 1. Open IIS on the ...

  4. 修改ASP.NET文件上传大小限制

    转自:http://www.hello-code.com/blog/asp.net/201603/5954.html 要点: 1.web.config中的<httpRuntime maxRequ ...

  5. [转]微信小程序之加载更多(分页加载)实例 —— 微信小程序实战系列(2)

    本文转自;http://blog.csdn.net/michael_ouyang/article/details/56846185 loadmore 加载更多(分页加载) 当用户打开一个页面时,假设后 ...

  6. jade——创建第一个jade模板

    什么是jade? jade是node.js的一个模板引擎,参考了haml的语法,是简写的html语言. 使用单个标签代替双标签,类似于Python,通过缩进来确定从属关系,没有结束符号,非常简洁,使用 ...

  7. ASP.NET MVC 学习笔记-1.ASP.NET MVC 基础

    ASP.NET MVC在原来ASP.NET的基础上抛弃了基于页面的架构风格,使用了全新的MVC(模型-视图-控制器)架构的一种技术. 目前,它和ASP.NET都共存在.NET Framework之上. ...

  8. Docker 更改镜像存储位置

    在使用 Docker 的过程中,如果我们一切都以默认的设置进行操作的话,在使用一段时间之后你应该会发现系统的根目录空间越来越少,直到有一天发现空间都被占满了,最后发现原来是被 Docker 占用了.所 ...

  9. styled-components 弃用 injectGlobal

    styled-components 最新版本是v4.1.2,但是从v4开始,就酱原来的injectGlobal方法用createGlobalStyle替换了.用法上也有一些不同了: 我今天直接引inj ...

  10. Mysql 删除数据表的三种方式详解

    用法: 1.当你不再需要该表时, 用 drop; 2.当你仍要保留该表,但要删除所有记录时, 用 truncate; 3.当你要删除部分记录或者有可能会后悔的话, 用 delete. 删除强度:dro ...