从其他一些帖子中我成功地为音乐播放器提供了一切。
最后一步是设置MPNowPlayingInfoCenter
值。
不幸的是,一旦我这样做,应用程序就失去了接收remoteControlEvents的能力,如果我在任何其他View Controller中而不是设置属性的那个。将应用程序放在后台的任何其他VC除了" Music VC" (这是一个选项卡应用程序和音乐只是一个选项卡)
我的AppDelegate:
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
//here is other stuff for push-notifications etc.
UIApplication.sharedApplication().beginReceivingRemoteControlEvents()
AVAudioSession.sharedInstance().setCategory(AVAudioSessionCategoryPlayback, error: nil)
return true
}
MusicVC:
class MusicVC:UIViewController, UITableViewDelegate,UITableViewDataSource,UICollectionViewDataSource, UICollectionViewDelegate {
var myPlayer:AVQueuePlayer!
override func viewDidLoad() {
super.viewDidLoad()
//tableView and other setup
self.becomeFirstResponder()
}
//MARK: - InfoCenter Methods
func setMediaCenterInfo() {
let mpic = MPNowPlayingInfoCenter.defaultCenter()
var albumArtWork = MPMediaItemArtwork(image: UIImage(named:"testImage"))
var fullString = self.currentSong.title as String
var splitArray = fullString.componentsSeparatedByString(" - ")
var artistName: String = splitArray[0]
var titleString: String? = splitArray.count > 1 ? splitArray[1] : nil
if titleString != nil {
mpic.nowPlayingInfo =
[
MPMediaItemPropertyArtwork:albumArtWork,
MPMediaItemPropertyTitle:titleString!,
MPMediaItemPropertyArtist:artistName
]
} else {
mpic.nowPlayingInfo =
[
MPMediaItemPropertyArtwork:albumArtWork,
MPMediaItemPropertyTitle:fullString
]
}
//Does get set correctly and shows in Info Center as well as Lock-Screen
}
override func canBecomeFirstResponder() -> Bool {
return true
}
override func remoteControlReceivedWithEvent(event: UIEvent) {
if event.type == UIEventType.RemoteControl {
switch event.subtype {
case .RemoteControlTogglePlayPause:
println("TOGGLE PLAY PAUSE")
//self.playToggleTapped(self)
case .RemoteControlPlay:
println("ONLY PLAY BUTTON")
//self.playToggleTapped(self)
case .RemoteControlPause:
println("ONLY PAUSE BUTTON")
//self.playToggleTapped(self)
case .RemoteControlNextTrack:
println("next")
//self.nexButtonTapped(self)
case .RemoteControlPreviousTrack:
//self.previousButtonTapped(self)
println("previous")
default:
break
}
}
}
}
显示另一个VC时,FirstResponder是否会自动更改?感谢提示解决这个问题。
答案 0 :(得分:0)
如果您仍然有兴趣找到一种方法来做到这一点。
您可以创建一个类来使用单例设置AudioPlayer。在此AudioPlayer类中,您将设置MPNowPlayingInfoCenter值和UIApplication.sharedApplication()。beginReceivingRemoteControlEvents()。
然后从viewController中'启动'你的播放器和所有viewController显示在MPNowPlayingInfoCenter值之后将继续显示在前景和后台视图中。如果你调用一个'BEFORE'的视图控制器(视图层次结构)'音频启动'viewController,音频将继续播放(前景和背景),但是你的MPNowPlayingInfoCenter数据不会显示。
要让它在整个应用程序中传播,您可能必须在“音频启动”发生时向AppDelegate(NSNotifcation.addObserver ..)发布通知(在您的AudioPlayer中),然后将MPNowPlayingInfoCenter值设置为AppDelegate中的函数。我现在正在这样做,所以如果你还在寻找解决方案,请告诉我。感谢