Go to file
Thong Nguyen 08287bc6a7 Merge pull request #24 from gangverk/master
Add support for HE-AAC
2013-05-17 11:26:45 -07:00
Audjustable Merge pull request #24 from gangverk/master 2013-05-17 11:26:45 -07:00
Audjustable.xcodeproj Added missing test app and static lib project schemes 2013-04-08 20:41:16 +01:00
.gitignore Add xcuserdata to gitignore 2013-03-24 16:25:46 +00:00
Audjustable.podspec Update podspec to version 0.0.5 2013-05-17 17:22:32 +00:00
Default-568h@2x.png Added AutoRecoveringHttpDataSource 2012-10-17 11:57:27 +01:00
LICENSE Adding podspec and LICENSE for Cocoapods integratino 2013-04-08 10:54:23 +00:00
README.md Updated README 2013-05-03 18:46:34 +01:00

README.md

Audjustable Audio Streamer

Homepage

Audjustable is audio streaming class for iOS and OSX. Audjustable uses CoreAudio to decompress and playback audio whilst providing a clean and simple object-oriented API.

The primary motivation of this project was to decouple the input (DataSource/InputStreams) from the actual player logic in order to allow advanced customizable input handling such as: HTTP streaming, encryption, auto-recovery, dynamic-buffering. Along the way other features such as gapless playback were added as the opportunity arose.

Features

  • Simple OOP API
  • Easy to read source
  • Adjustable audio buffering
  • Mostly asynchronous API
  • Buffered and gapless playback
  • Easy to implement audio data sources (HTTP and local file system DataSources provided)
  • Easy to extend DataSource to support adaptive buffering, encryption etc
  • Optimised for low CPU/battery usage

Usage

Download the source which includes a simple audio player project that streams audio over HTTP or locally using the HttpDataSource or LocalFileDataSource classes respectively.

If you would like to integrate the AudioPlayer directly into your project you only need to copy the files inside the /Audjustable/Classes/AudioPlayer directory into your project.

Audjustable is also available as a Cooapod.

Code

There are two main classes. The DataSource class which is the abstract base class for the various compressed audio data sources (HTTP, local file are provided). The AudioPlayer class manages and renders audio from a queue DataSources.


// Create AudioPlayer

AudioPlayer* audioPlayer = [[AudioPlayer alloc] init];
audioPlayer.delegate = self;

// Queue on a URL to play.  Each queue item has a unique ID (item1) that to identify the related file in delegate callbacks

[audioPlayer setDataSource:[audioPlayer dataSourceFromURL:@"https://github.com/downloads/tumtumtum/audjustable/sample.m4a"] withQueueItemId:@"item1"];

Other

Background playback on iOS is easily added to your application by calling the AudioSessionInitialize in your AppDelegate.

Authors and Contributors

Copyright 2012, Thong Nguyen (@tumtumtum)