【事象】
低速回線(3G)でAVPlayer使って動画を再生するとAVPlayerItemの「presentationSize」が変わる。一瞬期待通りのサイズで動画が再生されるが、すぐに潰れた状態になる。
4G回線やWifi接続中は発生しません。
当事象の発生前後の「presentationSize」の値です。
発生前:playerItem.presentationSize: (width = 432, height = 768)
発生後:playerItem.presentationSize: (width = 1280, height = 720)
【ソースコード】
Swift
1// 事象発生時のコード 2func setMovie(url:URL) { 3 let asset = AVURLAsset(url: url) 4 playerItem = AVPlayerItem(asset: asset) 5 player = AVPlayer(playerItem: playerItem) 6 7 playerLayer = AVPlayerLayer(player: player) 8 playerLayer.videoGravity = AVLayerVideoGravity.resizeAspect 9 playerLayer.frame = videoBaseView.frame 10 11 videoBaseView.layer.addSublayer(playerLayer) 12 13 NotificationCenter.default.addObserver(self, 14 selector: #selector(didPlayToEndTime), 15 name: .AVPlayerItemDidPlayToEndTime, object: playerItem) 16 17 player.play() 18}
プロジェクトのコードそのまま載せることができないので関係なさそうな部分は省略してあります。
情報に不足があれば教えてください。
【試したこと】
低速回線の場合のみ発生するため、URLから動画を取得できていないまま再生しているのではないかと考え、動画の取得状況をKVOで監視し、完了してから再生するように変更しました。
Swift
1// KVO追加のコード 2func setMovie(url:URL) { 3 let asset = AVURLAsset(url: url) 4 playerItem = AVPlayerItem(asset: asset) 5 player = AVPlayer(playerItem: playerItem) 6 7 // AVPlayerItemに対してKVOをセット 8 playerItem.addObserver(self, forKeyPath: ”status”, options: [.new, .initial], context: nil) 9 10 NotificationCenter.default.addObserver(self, 11 selector: #selector(didPlayToEndTime), 12 name: .AVPlayerItemDidPlayToEndTime, object: playerItem) 13 14 player.play() 15} 16 17// KVO 18override func observeValue(forKeyPath keyPath: String?, 19 of object: Any?, 20 change: [NSKeyValueChangeKey : Any]?, 21 context: UnsafeMutableRawPointer?) { 22 23 guard let keyPath = keyPath else { 24 return 25 } 26 27 if keyPath == ”status” { 28 29 let status = playerItem.status 30 31 switch status { 32 case .unknown: 33 return 34 case .readyToPlay: 35 do { 36 playerLayer = AVPlayerLayer(player: player) 37 playerLayer.videoGravity = AVLayerVideoGravity.resizeAspect 38 playerLayer.frame = videoContentView.frame 39 40 videoBaseView.layer.addSublayer(playerLayer) 41 player.play() 42 } 43 case .failed: 44 return 45 } 46 } 47}
上記のコードで想定した通りステータスが完了の時のみ動画を再生させることができましたが、事象は解消しませんでした。動画が取得できているかどうかは関係ないのでしょうか。
解決策やご助言いただけると助かります。
よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー