1

源自其他一些帖子,我成功地为音乐播放器做好了一切。

最后一步是设置MPNowPlayingInfoCenter值。

不幸的是,一旦我这样做,应用程序就会失去接收 remoteControlEvents 的能力,如果我位于设置属性的视图控制器之外的任何其他视图控制器中。将应用程序置于“音乐 VC”以外的任何其他 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
}

音乐VC:

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 会自动更改吗?感谢您提供解决此问题的提示。

4

1 回答 1

0

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

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

然后从“启动”你的播放器的 viewController 和所有在 MPNowPlayingInfoCenter 值之后显示的 viewController 将继续显示在前景和背景视图中。如果您将“之前”(视图层次结构)的视图控制器称为“音频启动”视图控制器,则音频将继续播放(前景和背景),但您来自 MPNowPlayingInfoCenter 的数据将不会显示。

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

于 2015-12-03T14:39:02.310 回答