版本記錄
版本號 | 時間 |
---|---|
V1.0 | 2017.12.28 |
前言
ios系統中有很多方式可以播放音頻文件,這里我們就詳細的說明下播放音樂文件的原理和實例。感興趣的可以看我寫的上面幾篇。
1. 幾種播放音頻文件的方式(一) —— 播放本地音樂
2. 幾種播放音頻文件的方式(二) —— 音效播放
3. 幾種播放音頻文件的方式(三) —— 網絡音樂播放
4. 幾種播放音頻文件的方式(四) —— 音頻隊列服務(Audio Queue Services)(一)
5. 幾種播放音頻文件的方式(五) —— 音頻隊列服務(Audio Queue Services)簡介(二)
6. 幾種播放音頻文件的方式(六) —— 音頻隊列服務(Audio Queue Services)之關于音頻隊列(三)
7. 幾種播放音頻文件的方式(七) —— 音頻隊列服務(Audio Queue Services)之錄制音頻(四)
8. 幾種播放音頻文件的方式(八) —— 音頻隊列服務(Audio Queue Services)之播放音頻(五)
框架基本
Media Player
框架也可以播放聲音文件。添加從您的應用程序中查找和播放歌曲,音頻播客,音頻書籍等功能。
使用之前要引入框架文件
#import <MediaPlayer/MediaPlayer.h>
1. Overview
媒體播放器框架為開發者提供了幾種播放媒體的方式。 內置的音樂播放器提供了一種訪問和播放應用中用戶音樂庫音頻的簡單方法。 外部音樂播放器也可以從用戶的音樂庫中檢索和播放媒體項目。 要使用戶能夠播放包含MPMediaItem
對象的視頻,請使用AVPlayer
。 您無法使用Media Player
框架播放視頻媒體項目。
重要:從iOS 10開始,訪問用戶的媒體庫需要用戶的同意。 添加
Privacy - Media Library Usage Description
密鑰和應用Info.plist
文件的密鑰說明。 如果該鍵未添加到項目中,您的應用程序將崩潰。
使用其中一個內置音樂播放器,使用戶能夠從您的應用程序的音樂庫中播放選擇的音頻。 例如,您可以讓用戶在嘗試完成特定游戲級別時從應用內播放自己的音樂。
加入MusicKit
,允許用戶從您的應用程序和游戲中本地播放Apple Music及其本地音樂庫。 用戶向其Apple Music
帳戶提供權限后,您的應用可以創建播放列表,將歌曲添加到其音樂庫,并播放Apple音樂目錄中的數百萬首歌曲。 如果您的應用檢測到該用戶還不是Apple Music
成員,則可以在您的應用內提供試用。
您可以將兩種類型的內置媒體播放器中的一種整合到您的應用中,具體取決于您的目標。 如果您希望在應用中進行的更改也影響Music
應用,請使用系統播放器。 如果您想在播放音頻時按原樣離開音樂應用程序,請使用應用程序播放器。 在決定播放器之后,使用媒體查詢media queries
來檢索將填充播放器的媒體項目。
2. API
下面我們看一下該框架的API
#import <MediaPlayer/MediaPlayerDefines.h>
#import <TargetConditionals.h>
#if TARGET_OS_IPHONE
#import <MediaPlayer/MPMediaItemCollection.h>
#import <MediaPlayer/MPMediaLibrary.h>
#import <MediaPlayer/MPMediaPickerController.h>
#import <MediaPlayer/MPMediaPlaylist.h>
#import <MediaPlayer/MPMediaQuery.h>
#import <MediaPlayer/MPMediaQuerySection.h>
#import <MediaPlayer/MPMoviePlayerController.h>
#import <MediaPlayer/MPMoviePlayerViewController.h>
#import <MediaPlayer/MPMusicPlayerApplicationController.h>
#import <MediaPlayer/MPMusicPlayerController.h>
#import <MediaPlayer/MPMusicPlayerQueueDescriptor.h>
#import <MediaPlayer/MPPlayableContentDataSource.h>
#import <MediaPlayer/MPPlayableContentDelegate.h>
#import <MediaPlayer/MPPlayableContentManager.h>
#import <MediaPlayer/MPPlayableContentManagerContext.h>
#import <MediaPlayer/MPVolumeSettings.h>
#import <MediaPlayer/MPVolumeView.h>
#import <MediaPlayer/NSUserActivity+MediaPlayerAdditions.h>
#endif
#import <MediaPlayer/AVFoundation+MPNowPlayingInfoLanguageOptionAdditions.h>
#import <MediaPlayer/MPContentItem.h>
#import <MediaPlayer/MPError.h>
#import <MediaPlayer/MPMediaItem.h>
#import <MediaPlayer/MPNowPlayingInfoCenter.h>
#import <MediaPlayer/MPNowPlayingInfoLanguageOption.h>
#import <MediaPlayer/MPRemoteCommand.h>
#import <MediaPlayer/MPRemoteCommandCenter.h>
#import <MediaPlayer/MPRemoteCommandEvent.h>
#import <MediaPlayer/MPRemoteControlTypes.h>
框架結構
下面我們先看一下框架基本結構。
下面我們就看一下這個框架的詳細結構。
1. Built-In Music Playback
-
Playing Audio Using the Built-In Music Player
- 在應用程序內部創建媒體播放器,以播放用戶媒體庫中的音頻。
-
MPMusicPlayerController
- 用于播放設備Music 應用程序庫中的音頻媒體項目的對象。
-
MPMediaPlayback
- 定義控制音頻媒體回調接口的協議。
-
MPSystemMusicPlayerController
- 在Music 應用程序中播放視頻的協議。
2. Media Library Synchronization
-
MPMediaLibrary
- 表示設備上已同步媒體項目狀態的對象。
3. Media Item Queries
-
Using Filters to Create Specialized Queries
- 在填充音樂播放器隊列之前,將查詢過濾器添加到查詢中。
-
MPMediaQuery
- 通過過濾器和分組類型指定來自設備媒體庫的一組媒體項目的查詢。
-
MPMediaQuerySection
- 媒體查詢中的一系列媒體項目或媒體項目集合。
-
MPMediaPropertyPredicate
- 一組謂詞,用于定義媒體查詢中使用的過濾器。
-
MPMediaPredicate
- 定義在媒體查詢中過濾媒體的類的抽象類。
4. Media Player Queues
-
MPMusicPlayerControllerQueue
- 包含要由應用程序隊列媒體播放器播放的媒體項目的不可變隊列。
-
MPMusicPlayerControllerMutableQueue
- 包含媒體播放器要播放的媒體項目的可變隊列。
-
MPMusicPlayerApplicationController
- 媒體播放器對象,用于修改當前正在播放的隊列。
-
MPMusicPlayerMediaItemQueueDescriptor
- 用于修改播放器的媒體隊列中的音頻媒體項目的一組屬性和方法。
-
MPMusicPlayerStoreQueueDescriptor
- 一組屬性和方法,用于根據播放器隊列中的存儲標識符修改項目。
-
MPMusicPlayerPlayParametersQueueDescriptor
- 基于
MusicKit API
結果返回的播放參數,用于修改項目播放方式的一組屬性和方法。
- 基于
-
MPMusicPlayerQueueDescriptor
- 音頻媒體項目和存儲隊列描述符的抽象基類。
5. Media Items and Playlists
-
MPMediaItem
- 表示媒體庫中包含的單個項目的屬性集合。
-
MPMediaItemArtwork
- 與媒體項目相關聯的圖形圖像,例如音樂專輯封面。
-
MPMediaItemCollection
- 來自媒體庫的有序媒體項目集。
-
MPMediaPlaylist
- 可播放的相關媒體項目集合。
-
MPMediaPlaylistCreationMetadata
- 播放列表首次創建時用于描述播放列表的一組屬性。
-
MPMediaEntity
- 媒體項目,媒體項目集合和媒體播放列表實例的抽象超類。
6. Media Player User Interface
-
Adding Individual Media Items Using a Media Picker
- 將媒體選擇器添加到您的應用中,以允許用戶挑選單個音樂項目。
-
MPMediaPickerController
- 提供用于選擇媒體項目的圖形界面的專用視圖控制器。
-
MPVolumeView
- 用于設置系統音頻輸出音量的滑塊控件,以及用于選擇音頻輸出路徑的按鈕。
-
Global Volume Setting Methods
- 用于設置音量警報窗口狀態的全局函數。
7. Now Playing Information
提供有關當前曲目的信息。
-
MPNowPlayingInfoCenter
- 一個對象,用于設置您的應用程序正在播放媒體的即時播放信息。
-
MPNowPlayingInfoLanguageOption
- 一組用于為正在播放的項目設置語言選項的接口。
-
MPNowPlayingInfoLanguageOptionGroup
- 一組語言選項,一次只能激活一種語言選項。
-
Language Option Characteristic Constants
- 常量用于定義語言特性。
8. External Player and System Event Handling
支持外部媒體播放器或系統顯示的控件的播放控制。
-
Handling External Player Events Notifications
- 處理外部媒體播放器的事件。
-
Remote Command Center Events
- 設置遠程指揮中心來處理媒體播放器事件。
-
Track Navigation Events
- 響應請求以更改媒體項目的部分播放。
-
Media Playback Mode Events
- 回應媒體項目播放方式的變化。
-
Feedback and Rating Events
- 響應即將到來的反饋和評級事件
9. External Media Player Items
提供內容和與外部媒體播放器進行交互的接口
-
MPContentItem
- 包含顯示給用戶的特定媒體項目信息的對象。
-
MPPlayableContentManager
- 共享內容管理器,用于控制你的媒體app與系統提供的或外部媒體播放器界面之間的接口。
-
MPPlayableContentManagerContext
- 表示可播放端點當前狀態的對象。
10. Errors
-
MPErrorCode
- 媒體播放器錯誤域的錯誤代碼。
-
MPErrorDomain
- 媒體播放器框架錯誤域。
11. Deprecated
-
Deprecated Symbols
- 這些符號已被棄用,不再推薦使用。
后記
未完,待續~~~