Go to file
Anton 6b6a5ad434 STKAutoRecoveringHTTPDataSource http errors handling fix 2016-09-22 16:07:06 +03:00
ExampleApp Changed enums to NS_ENUM to better support Swift. Added launch images to remove warnings 2015-12-04 22:47:14 +00:00
ExampleAppMac Smallf ix to ExampleAppMac app 2014-11-08 20:56:55 +00:00
StreamingKit STKAutoRecoveringHTTPDataSource http errors handling fix 2016-09-22 16:07:06 +03:00
StreamingKit.xcworkspace Added basic support for Icecast streams 2014-11-08 15:45:40 +00:00
.gitignore Add xcuserdata to gitignore 2013-03-24 16:25:46 +00:00
LICENSE Fixed License 2015-10-29 18:16:01 +00:00
README.md spelling fix 2015-06-18 14:14:47 -07:00
StreamingKit-head.podspec Removed unnecessary synthesized properties. Made STKFrameFilterEntry public readonly. Removed AudioUnit framework requirement for iOS n podspec 2014-02-03 17:23:53 +00:00
StreamingKit.podspec Updated podspec 2016-01-04 11:06:47 +00:00

README.md

StreamingKit

StreamingKit (formally Audjustable) is an audio playback and streaming library for iOS and Mac OSX. StreamingKit uses CoreAudio to decompress and playback audio (using hardware or software codecs) whilst providing a clean and simple object-oriented API.

The primary motivation of this project was to decouple the input data sources from the actual player logic in order to allow advanced customizable input handling such as HTTP progressive download based streaming, encryption/decryption, auto-recovery, dynamic-buffering. StreamingKit is the only streaming and playback library that supports dead-easy gapless playback between audio files of differing formats.

Main Features

  • Free OSS.
  • Simple API.
  • Easy to read source.
  • Carefully multi-threaded to provide a responsive API that won't block your UI thread nor starve the audio buffers.
  • Buffered and gapless playback between all format types.
  • Easy to implement audio data sources (Local, HTTP, AutoRecoveringHTTP DataSources are provided).
  • Easy to extend DataSource to support adaptive buffering, encryption, etc.
  • Optimised for low CPU/battery usage (0% - 1% CPU usage when streaming).
  • Optimised for linear data sources. Random access sources are required only for seeking.
  • StreamingKit 0.2.0 uses the AudioUnit API rather than the slower AudioQueues API which allows real-time interception of the raw PCM data for features such as level metering, EQ, etc.
  • Power metering
  • Inbuilt equalizer/EQ (iOS 5.0 and above, OSX 10.9 Mavericks and above) with support for dynamically changing/enabling/disabling EQ while playing.
  • Example apps for iOS and Mac OSX provided.

Installation

StreamingKit is available as a Cocoapod. You can also simply copy all the source files located inside StreamingKit/StreamingKit/* into your Xcode project.

Example

There are two main classes. The STKDataSource class which is the abstract base class for the various compressed audio data sources. The STKAudioPlayer class manages and renders audio from a queue DataSources. By default STKAudioPlayer will automatically parse URLs and create the appropriate data source internally.

Play an MP3 over HTTP

STKAudioPlayer* audioPlayer = [[STKAudioPlayer alloc] init];

[audioPlayer play:@"http://www.abstractpath.com/files/audiosamples/sample.mp3"];

Gapless playback

STKAudioPlayer* audioPlayer = [[STKAudioPlayer alloc] init];

[audioPlayer queue:@"http://www.abstractpath.com/files/audiosamples/sample.mp3"];
[audioPlayer queue:@"http://www.abstractpath.com/files/audiosamples/airplane.aac"];

Intercept PCM data just before its played

[audioPlayer appendFrameFilterWithName:@"MyCustomFilter" block:^(UInt32 channelsPerFrame, UInt32 bytesPerFrame, UInt32 frameCount, void* frames)
{
   ...
}];

More

More documentation is available on the project Wiki

Authors and Contributors

Copyright (c) 2012-2014, Thong Nguyen (@tumtumtum)