用于在 Firebase 数据库中播放来自 URL 的视频的 AVPLayer

AVPLayer to play video from URL in Firebase Database

我有原型单元格,可以自动从 Firebase 数据库中提取文本。我也想将视频合并到其中。我将如何使用 AVPlayer 从 FireBase 数据库中的 URL 播放视频。我希望它尽可能自动。

我不是经验丰富的开发人员,因此遇到困难,所以请提供 "baby level" 答案。

这是从 firebase 中提取的单元格的代码。

        //
//  FirebaseVidoes.swift
//  Faces of the Holocaust Photographic History
//
//  Created by New User on 8/25/17.
//  Copyright © 2017 New User. All rights reserved.
//

import UIKit
import Firebase
import AVKit
import AVFoundation

struct postStruct {
let title : String!
let message : String!
//let image : UIImage!
}


class FirebaseVidoes: UITableViewController {


var posts = [postStruct]()



override func viewDidLoad() {
    super.viewDidLoad()

tableView.backgroundView = UIImageView(image: UIImage(named: 
"polandBackgroundBlur.jpg"))


    let databaseRef = Database.database().reference()


databaseRef.child("Posts").queryOrderedByKey().observe(.childAdded, 
with: {

        snapshot in

        let snapshotValue = snapshot.value as? NSDictionary
        let title = snapshotValue?["title"] as? String
        let message = snapshotValue?["message"] as? String
        //let image = snapshotValue?["image"] as? UIImage

        self.posts.insert(postStruct(title: title, message: message) 
, at: 0)
        self.tableView.reloadData()


    })


    //post()
    // Do any additional setup after loading the view.
}


func post(){

    let title = "Title"
    let message = "Message"


    let post : [String : AnyObject] = ["title": title as AnyObject,
                                        "message": message as 
AnyObject]


    let databaseRef = Database.database().reference()

    databaseRef.child("Posts").childByAutoId().setValue(post)


}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}


override func tableView(_ tableView: UITableView, 
numberOfRowsInSection section: Int) -> Int {

    return posts.count

}



override func tableView(_ tableView: UITableView, cellForRowAt 
indexPath: IndexPath) -> UITableViewCell {

    var cell = tableView.dequeueReusableCell(withIdentifier: "Cell")

    let label1 =  cell?.viewWithTag(1) as! UILabel
        label1.text = posts[indexPath.row].title

    let label2 = cell?.viewWithTag(2) as! UILabel
        label2.text = posts[indexPath.row].message

    //let image1 = cell?.viewWithTag(3) as! UIImage
        //image1.UIimage = posts[indexPath.row].image



    return cell!

}




}

这里是 AVPlayer 代码:

//  VideoTestViewController.swift
//  Faces of the Holocaust Photographic History
//
//  Created by New User on 8/26/17.
//  Copyright © 2017 New User. All rights reserved.
//

import UIKit
import AVKit
import AVFoundation


class VideoTest: UIViewController {

override func viewDidLoad() {
    super.viewDidLoad()

    // Do any additional setup after loading the view.
}
@IBAction func watchVideoDidClick(_ sender: Any) {

    playExternalVideo()
}

let videoURL = "SOMEVIDEOURL"

func playExternalVideo(){

    let videoURL = NSURL(string: self.videoURL)!

    let player = AVPlayer(url: videoURL as URL)
    let playerViewController = AVPlayerViewController()

    playerViewController.player = player

    self.present(playerViewController, animated: true) {
        () -> Void in
        playerViewController.player!.play()
    }

}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}


}

如何合并这些视频以获得自动填充到单元格中的视频。

EDIT 这里是修改后的代码

   //Code Beginning    
   import UIKit
   import Firebase
   import AVKit
   import AVFoundation

   struct postStruct {
let title : String!
let message : String!
let url : URL!
//let image : UIImage!

}

class FirebaseVidoes: UITableViewController {

var posts = [postStruct]()



override func viewDidLoad() {
    super.viewDidLoad()

    tableView.backgroundView = UIImageView(image: UIImage(named: "polandBackgroundBlur.jpg"))


    let databaseRef = Database.database().reference()

    databaseRef.child("Posts").queryOrderedByKey().observe(.childAdded, with: {

        snapshot in

        let snapshotValue = snapshot.value as? NSDictionary
        let title = snapshotValue?["title"] as? String
        let message = snapshotValue?["message"] as? String
        let url = snapshotValue?["url"] as? URL
        //let image = snapshotValue?["image"] as? UIImage

        self.posts.insert(postStruct(title: title, message: message, url: url) , at: 0)
        self.tableView.reloadData()




    })


    //post()
    // Do any additional setup after loading the view.
}

/* 函数 post(){

    let title = "Title"
    let message = "Message"


    let post : [String : AnyObject] = ["title": title as AnyObject,
                                        "message": message as AnyObject]


    let databaseRef = Database.database().reference()

    databaseRef.child("Posts").childByAutoId().setValue(post)


} */

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}


override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

    return posts.count

}



override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    var cell = tableView.dequeueReusableCell(withIdentifier: "Cell")

    let label1 =  cell?.viewWithTag(1) as! UILabel
        label1.text = posts[indexPath.row].title

    let label2 = cell?.viewWithTag(2) as! UILabel
        label2.text = posts[indexPath.row].message



    //let image1 = cell?.viewWithTag(3) as! UIImage
        //image1.UIimage = posts[indexPath.row].image



    return cell!




}

func tableView(_tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

    var selectedIndex = indexPath

    let url = URL(string: "url")
    let player = AVPlayer(url: url!)
    let playerViewController = AVPlayerViewController()
    playerViewController.player = player
    self.present(playerViewController, animated: true) {
        playerViewController.player!.play()
    }

}

}

试试这个在新屏幕上显示:

  1. 导入:导入 AVKit,导入 AVFoundation
  2. 然后当用户点击单元格时(在 TableView 的 didSelectRow 方法中)

    let videoURL = URL(string: "url")
    let player = AVPlayer(url: videoURL!)
    let playerViewController = AVPlayerViewController()
    playerViewController.player = player
    self.present(playerViewController, animated: true) {
        playerViewController.player!.play()
    }
    

让它在牢房内播放更难。正如您评论的那样,这对您现在有用。

编辑:在评论中回答您的问题: 那应该很容易。我看到你已经有了这个:

self.posts.insert(postStruct(title: title, message: message), at: 0)

这意味着您要将新的 Post 对象添加到 posts 数组中。然后你重新加载数据。

所以现在,我猜你的 snapshotValue 应该有一个 URL,对吧?因为如果您说您需要播放视频,那么 URL 从何而来?所以我的猜测是快照有这个 url。因此,您需要向 Post 对象添加新的 属性,这是一个 url。

所以现在每个单元格都将包含一个 Post 对象,该对象有一个 url。当用户点击它时,您只需播放 post 的 url。清楚了吗?

编辑2: 只需这样做:

let url = posts[indexPath.row].url

编辑 3:

  1. 将第 44 行更改为:

let urlString = snapshotValue?["url"] as? String

let url = URL(string: urlString!)

  1. 将您的 didSelect 方法更改为: override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath)