应用程序在设置MPNowPlayingInfoCenter时丢失远程控制输入

时间:2015-08-28 14:45:44

标签: swift avplayer mpnowplayinginfocenter

从其他一些帖子中我成功地为音乐播放器提供了一切。

最后一步是设置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是否会自动更改?感谢提示解决这个问题。

1 个答案:

答案 0 :(得分:0)

如果您仍然有兴趣找到一种方法来做到这一点。

您可以创建一个类来使用单例设置AudioPlayer。在此AudioPlayer类中,您将设置MPNowPlayingInfoCenter值和UIApplication.sharedApplication()。beginReceivingRemoteControlEvents()。

然后从viewController中'启动'你的播放器和所有viewController显示在MPNowPlayingInfoCenter值之后将继续显示在前景和后台视图中。如果你调用一个'BEFORE'的视图控制器(视图层次结构)'音频启动'viewController,音频将继续播放(前景和背景),但是你的MPNowPlayingInfoCenter数据不会显示。

要让它在整个应用程序中传播,您可能必须在“音频启动”发生时向AppDelegate(NSNotifcation.addObserver ..)发布通知(在您的AudioPlayer中),然后将MPNowPlayingInfoCenter值设置为AppDelegate中的函数。我现在正在这样做,所以如果你还在寻找解决方案,请告诉我。感谢