ModernAVPlayer alternatives and similar libraries
Based on the "Audio" category.
Alternatively, view ModernAVPlayer alternatives based on common mentions on social networks and blogs.
-
AudioKit
Swift audio synthesis, processing, & analysis platform for iOS, macOS and tvOS -
EZAudio
An iOS and macOS audio visualization framework built upon Core Audio useful for anyone doing real-time, low-latency audio processing and visualizations. -
StreamingKit
A fast and extensible gapless AudioPlayer/AudioStreamer for OSX and iOS (iPhone, iPad) -
novocaine
Painless high-performance audio on iOS and Mac OS X -
FDWaveformView
Reads an audio file and displays the waveform -
PandoraPlayer
🅿️ PandoraPlayer is a lightweight music player for iOS, based on AudioKit and completely written in Swift. -
SubtleVolume
Replace the system volume popup with a more subtle indicator. -
SwiftySound
SwiftySound is a simple library that lets you play sounds with a single line of code. -
AudioPlayer
AudioPlayer is syntax and feature sugar over AVPlayer. It plays your audio files (local & remote). -
IQAudioRecorderController
A drop-in universal library allows to record audio within the app with a nice User Interface. -
Jukebox
Player for streaming local and remote audio files. Written in Swift. -
TheAmazingAudioEngine2
The Amazing Audio Engine is a sophisticated framework for iOS audio applications, built so you don't have to. -
MusicKit
A framework for composing and transforming music in Swift -
ESTMusicIndicator
Cool Animated music indicator view written in Swift -
QuietModemKit
iOS framework for the Quiet Modem (data over sound) -
FDSoundActivatedRecorder
Start recording when the user speaks -
AudioPlayerSwift
AudioPlayer is a simple class for playing audio in iOS, macOS and tvOS apps. -
Chirp
The easiest way to prepare, play, and remove sounds in your Swift app! -
SRGMediaPlayer-iOS
An advanced media player library, simple and reliable -
sound-fader-ios
A sound fader for AVAudioPlayer written in Swift for iOS, tvOS and macOS. -
BPMAnalyser
Fast and simple instrument to get the BPM rate from your audio-files. -
QHSpeechSynthesizerQueue
Queue management system for AVSpeechSynthesizer
Appwrite - The Open Source Firebase alternative introduces iOS support
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of ModernAVPlayer or a related project?
README
ModernAVPlayer
ModernAVPlayer
is a persistence AVPlayer
wrapper
++ Cool features ++
- Get 9 nice and relevant player states (playing, buffering, loading, loaded...)
- Persistence player to resume playback after bad network connection
even in background mode(bug from version 1.5.1) - Manage headphone interactions, call & siri interruptions, now playing informations
- Add your own plug-in to manage tracking, events...
- RxSwift compatible
- Loop mode
- Log available by domain ***
Known issue
From version 1.5.1, resume playback from background mode failed. If you have any suggestion, please help.
Use of mixWithOther AVAudiosession CategoryOptions is not a solution.
Menu
Requirements
- iOS 10.0+
- tvOS 10.0+
In order to support background mode, append the following to your
Info.plist
:<key>UIBackgroundModes</key> <array> <string>audio</string> </array>
Installation
Swift Package Manager
Supported version: swift-tools-version:5.0
// Package.swift
import PackageDescription
let package = Package(
name: "Sample",
dependencies: [
.package(url: "https://github.com/noreasonprojects/ModernAVPlayer", from: "X.X.X")
],
targets: [
.target(name: "Sample", dependencies: ["ModernAVPlayer"])
]
)
CocoaPods
CocoaPods is a dependency manager for Cocoa projects. You can install it with the following command:
$ gem install cocoapods
CocoaPods 1.3+ is required to build ModernAVPlayer.
To integrate ModernAVPlayer
into your Xcode project using CocoaPods, specify it in your Podfile
:
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '10.0'
use_frameworks!
target '<Your Target Name>' do
pod 'ModernAVPlayer'
end
Then, run the following command:
$ pod install
Getting started
Create media from URL
let media = ModernAVPlayerMedia(url: URL, type: MediaType)
Create media from AVPlayerItem
let media = ModernAVPlayerMediaItem(item: AVPlayerItem, type: MediaType, metadata: PlayerMediaMetadata)
Instanciate the wrapper
let player = ModernAVPlayer()
Load and play the media
player.load(media: media, autostart: true)
Track on repeat
player.loopMode = true
↓ State / Command → | loadMedia | play | pause | stop | seek |
---|---|---|---|---|---|
Init | O | X | O | O | X |
Loading | O | X | O | O | X |
Loaded | O | O | O | O | O |
Buffering | O | X | O | O | O |
Playing | O | X | O | O | O |
Paused | O | O | X | O | O |
Stopped | O | O | O | X | O |
WaitingNetwork | O | X | O | O | X |
Failed | O | O | X | X | X |
Advanced
Custom configuration
All player configuration are available from PlayerConfiguration
protocol.
A default implementation ModernAVPlayerConfiguration
is provided with documentation
Remote command
If using default configuration file ( swift useDefaultRemoteCommand = true
), ModernAVPlayer use automatically all commands created by ModernAVPlayerRemoteCommandFactory
class
Documention available in ModernAVPlayerRemoteCommandFactory.swift
file
Custom command
Use your own
PlayerConfiguration
implementation with... useDefaultRemoteCommand = false ...
Create an array of commands conforming to
ModernAVPlayerRemoteCommand
protocol.let player = ModernAVPlayer(config: YourConfigImplementation()) let commands: [ModernAVPlayerRemoteCommand] = YourRemoteCommandFactory.commands player.remoteCommands = commands
You can use existing commands from public ModernAVPlayerRemoteCommandFactory
class.
Plugin
Use PlayerPlugin
protocol to create your own plugin system, like tracking Plugin.
RxSwift
Instead of using delegate pattern, you can use rx to bind player attributes.
Setup
Use pod 'ModernAVPlayer/RxSwift'
in the Podfile
Usage
let player = ModernAVPlayer() let state: Observable<ModernAVPlayer.State> = player.rx.state
Communication
- If you found a bug, make a pull request using
Simple Audio
template in the example section to demonstrate. - If you have a feature request, open an issue.
- If you want to contribute, submit a pull request.