AVPlayer 处于 ReadyToPlay 状态但无法开始播放

AVPlayer is in the ReadyToPlay status but unable to start a playback

这是我启动视频的代码:

let videoURL = NSURL(string: "https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4")
let playerAV = AVPlayer(url: videoURL! as URL)
let playerLayerAV = AVPlayerLayer(player: playerAV)
playerLayerAV.frame = ...
self.view.layer.addSublayer(playerLayerAV)
playerAV.play()

我可以看到视频预览,我也可以看到它正在加载,我什至可以移动滑块并看到预览正在更改为我选择的时间。但如果我点击播放 - 什么都不会发生。我尝试手动按下 "play" 按钮,我尝试以编程方式调用 .play,"Play" 按钮的状态变为“||”但随后立即切换回“>”。

我还在跟踪与播放器状态相关的调试信息,我注意到以下内容。就在我创建播放器时,状态如下:

Status: ReadyToPlay
TimeControl: WaitingToPlayAtSpecifiedRate
ReasonToWait: AVPlayerWaitingToMinimizeStallsReason
Time: {0/1 = 0.000}
Rate: 1
Loaded Time Ranges: [Location=0,Length=0]

它几乎立即改变了它的 TimeControl: Paused 和 Rate: 0:

Status: ReadyToPlay
TimeControl: Paused
ReasonToWait:
Time: {0/1 = 0.000}
Rate: 0
Loaded Time Ranges: [Location=0,Length=0]

在这两种情况下,当UI显示视频已完全加载并可以播放时,显示playerItem.LoadedTimeRanges有一个元素但长度和位置为0。

事实证明视频、视图或控制器设置没有问题。由于共享模式 audioSession,视频已加载并准备播放并立即暂停。它之前设置为 .record 以处理另一个应用程序用例。

解决方法是恢复原始的 audioSession 模式,其中包括播放,并且视频可以正常播放。