17

我正在尝试使用 MPMoviePlayerController 为 Swift 中的 iOS 应用程序播放视频。

我的目标是能够用苹果音乐之类的东西播放系统音乐,然后打开我的应用程序并混合音频,但我希望我的应用程序能够控制MPNowPlayingInfoCenter.

如何AVAudioSession.sharedInstance().setCategory(AVAudioSessionCategoryPlayback, withOptions: .MixWithOthers)在设置 MPNowPlayingInfoCenter 的同时使用?

谷歌地图在设置 MPNowPlayingInfoCenter 时会混入音频。以下是我尝试设置 MPNowPlayingInfoCenter 的方式:

func setMeta(){
    UIApplication.sharedApplication().beginReceivingRemoteControlEvents()
    self.becomeFirstResponder()
    if let player = PlayWorkoutViewController.player{
        let coverArt = MPMediaItemArtwork(image: UIImage(named: "AlbumArt")!)
        let dict: [String: AnyObject] = [
            MPMediaItemPropertyArtwork: coverArt,
            MPMediaItemPropertyTitle:workout.title,
            MPMediaItemPropertyArtist:"Alex",
            MPMediaItemPropertyAlbumTitle:workout.program.title,
            MPNowPlayingInfoPropertyPlaybackRate: player.currentPlaybackRate,
            MPNowPlayingInfoPropertyElapsedPlaybackTime: player.currentPlaybackTime,
            MPMediaItemPropertyPlaybackDuration: player.playableDuration
        ]
        MPNowPlayingInfoCenter.defaultCenter().nowPlayingInfo = dict
    }
}

当我尝试同时使用选项 ( .MixWithOthers) 播放外部音乐时,上述功能有效,但是当我尝试使用选项 ( .MixWithOthers) 播放外部音乐时,信息中心不会更新。

编辑1:只是为了让事情变得非常清楚,我已经可以正常播放视频我正在尝试使用其他背景音频播放视频,同时能够设置 MPNowPlayingInfoCenter。

4

3 回答 3

10

这在 iOS 中目前是不可能的。即使只是将您的类别选项更改为.MixWithOthers会导致您nowPlayingInfo被忽略。

我的猜测是 iOS 只考虑将非混合应用程序包含在 中MPNowPlayingInfoCenter,因为如果同时播放多个混合应用程序,则不确定哪个应用程序会显示在(例如)控制中心中。

如果 iOS 使用尽力而为的方法来选择“正在播放的应用程序”,我会非常喜欢它,如下所示:

  1. 如果有一个非混音应用程序正在播放,请选择它。别的..
  2. 如果只有一个混音应用程序正在播放,请选择它。别的..
  3. 如果有多个混音应用程序正在播放,只需选择一个 :) 或不选择任何一个,我都可以。

如果您也喜欢这种行为,我建议您向 Apple 提交错误。

于 2016-01-12T15:12:10.177 回答
0

您是否尝试过实现自己的自定义函数来更新MPNowPlayingInfoCenter? 最近我在用一个AVAudioPlayer播放音乐,需要手动更新。

这基本上是我在加载新歌曲时调用的函数。

func updateNowPlayingCenter() {
    let center = MPNowPlayingInfoCenter.defaultCenter()
    if nowPlayingItem == nil {
        center.nowPlayingInfo = nil
    } else {
        var songInfo = [String: AnyObject]()

        // Add item to dictionary if it exists
        if let artist = nowPlayingItem?.artist {
            songInfo[MPMediaItemPropertyArtist] = artist
        }
        if let title = nowPlayingItem?.title {
            songInfo[MPMediaItemPropertyTitle] = title
        }
        if let albumTitle = nowPlayingItem?.albumTitle {
            songInfo[MPMediaItemPropertyAlbumTitle] = albumTitle
        }
        if let playbackDuration = nowPlayingItem?.playbackDuration {
            songInfo[MPMediaItemPropertyPlaybackDuration] = playbackDuration
        }
        if let artwork = nowPlayingItem?.artwork {
            songInfo[MPMediaItemPropertyArtwork] = artwork
        }
        center.nowPlayingInfo = songInfo
    }
}

我不确定在加载电影时执行此操作是否会覆盖 MPMoviePlayerController,但似乎值得一试。

此外,他们已经贬值MPMoviePlayerController并用AVPlayerViewController替换它,所以这也值得研究。

编辑:另外我会检查以确保您正确接收远程控制事件,因为这会影响信息中心显示的数据。

于 2016-01-06T01:11:41.113 回答
-1

要快速播放视频,请使用以下命令:-

func playVideoEffect() {
    let path = NSBundle.mainBundle().pathForResource("egg_grabberAnmi", ofType:"mp4")
    let url = NSURL.fileURLWithPath(path!)
    self.moviePlayer = MPMoviePlayerController(contentURL: url)
    if let player = moviePlayer {
        let screenSize: CGRect = UIScreen.mainScreen().bounds
        player.view.frame = CGRect(x: frame.size.width*0.10,y: frame.size.width/2, width:screenSize.width * 0.80, height: screenSize.width * 0.80)
        player.view.sizeToFit()
        player.scalingMode = MPMovieScalingMode.Fill
        player.fullscreen = true
        player.controlStyle = MPMovieControlStyle.None
        player.movieSourceType = MPMovieSourceType.File
        player.play()
        self.view?.addSubview(player.view)
        var timer = NSTimer.scheduledTimerWithTimeInterval(6.0, target: self, selector: Selector("update"), userInfo: nil, repeats: false)     
    }
}


// And Use the function to play Video
playVideoEffect()
于 2016-01-11T10:04:06.553 回答