我正在尝试将从库中选择的视频上传到 firebase 存储,然后获取与视频关联的 url 并通过单击播放按钮在 tableviewcell 中播放它。
我上传文件的方式是:
func postVideo(userId: String) {
self.progressBar.isHidden = false
let compressedURL = NSURL.fileURL(withPath: NSTemporaryDirectory() + NSUUID().uuidString + ".mov")
VideoOperation.compressVideo(inputURL: videoUrlPassed!, outputURL: compressedURL, handler: { (exportSession) in
guard let session = exportSession else {return}
let compressedVideoUrl = session.outputURL
let videoIdString = NSUUID().uuidString
let storageRef = Storage.storage().reference(forURL: Configuration.STORAGE_MAIN_REF).child("posts").child("videos").child(userId).child(videoIdString + ".mov")
let uploadTask = storageRef.putFile(from: compressedVideoUrl!, metadata: nil, completion: { (metadata, error) in
if error != nil {
ProgressHUD.showError(error?.localizedDescription)
return
}
let videoUrl = metadata?.downloadURL()?.absoluteString
})
}
然后我创建了一个模型来下载信息
extension Post {
static func videoPost(dictionary: [String:AnyObject]) -> Post {
let post = Post()
post._caption = dictionary["caption"] as? String
post._videoUrl = dictionary["videoUrl"] as? String
post._videoThumbUrl = dictionary["videoThumbUrl"] as? String
post._isVideo = dictionary["isVideo"] as? Bool
return post
}
在我有 tableview 的 Controller 中,我在 viewdidload 中加载信息:
func loadPosts() {
Database.database().reference().child("posts").observe(.childAdded) { (snapshot) in
if let dict = snapshot.value as? [String:AnyObject] {
let newPhotoPost = Post.photoPost(dictionary: dict)
if !newPhotoPost.isVideo {
self.posts.append(newPhotoPost)
} else {
let newVideoPost = Post.videoPost(dictionary: dict)
self.posts.append(newVideoPost)
}
self.tableView.reloadData()
}
}
}
然后在 cellForRowAt 中创建播放器:
if post.isVideo {
let url = URL(string: post.videoUrl)
cell.createPlayer(url: url!)
}
这是在我的 tableviewcell 中创建播放器的函数:
func createPlayer(url: URL) {
self.playerCell = AVPlayer(url: url)
self.playerLayerCell = AVPlayerLayer(player: playerCell)
self.playerLayerCell?.frame = videoContainerView.bounds
self.playerLayerCell?.videoGravity = AVLayerVideoGravity.resizeAspectFill
self.videoContainerView.layer.insertSublayer(playerLayerCell!, at: 0)
}
视频正在播放,但我有两个问题: 1)当我关闭 Controller 时,视频继续播放 2) 这是我遇到的最烦人的错误:
CredStore - performQuery - Error copying matching creds. Error=-25300, query={
class = inet;
"m_Limit" = "m_LimitAll";
"r_Attributes" = 1;
sync = syna;
如果我点击播放按钮,视频正在播放,但我真的无法理解该错误是什么!
如果有人能提供帮助,我将非常高兴!
谢谢!
最佳答案
每次使用模型对象提供的 url 重新初始化 AVPlayer 时,都会调用 tableview cellForRow。当在 tableview 中滚动时初始化新单元格时,将为新单元格创建新的 AVPlayer 实例。
错误一:可以调用UItableview的didEndDisplayingCell委托(delegate)方法停止播放器,当播放器速率不为0时停止播放器。
if (cell.player.rate != 0) && (cell.player.error == nil)) {
// player is playing
cell.player = nil;
}
错误 2:我不知道发生了什么。
关于ios - Swift 将视频上传到 Firebase 并在 UITableViewCell 中播放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47023146/