从firebase存储中检索图像以在tableView单元格上显示

时间:2017-12-23 01:12:38

标签: ios uitableview

我只需要帮助我使用firebase构建Instagram-clone并且我有一个问题,因为我无法从firebase存储中检索图像以显示在tableView单元格上,您可以帮助我,(

导入UIKit

导入FirebaseAuth

导入FirebaseDatabase

class HomeViewController:UIViewController,UITableViewDelegate {

@IBOutlet weak var tableview: UITableView!
var posts = [Post]()
override func viewDidLoad() {
    super.viewDidLoad()

    tableview.dataSource = self
    loadposts()

 //   var post = Post(captiontxt: "test", photoUrlString: "urll")
 //   print(post.caption)
 //   print(post.photoUrl)

}

func loadposts() {
    Database.database().reference().child("posts").observe(.childAdded){ (snapshot: DataSnapshot)in
        print(Thread.isMainThread)
          if let dict = snapshot.value  as? [String: Any]{
            let captiontxt = dict["caption"] as! String
            let photoUrlString = dict["photoUrl"] as! String
           let post = Post(captiontxt: captiontxt, photoUrlString: photoUrlString )
            self.posts.append(post)
            print(self.posts)
            self.tableview.reloadData()
        }
    }
}

@IBAction func logout(_ sender: Any) {
    do {
        try Auth.auth().signOut()
    }catch let logoutErrorr{
        print(logoutErrorr)
    }
    let storyboard = UIStoryboard(name: "Start", bundle: nil)
    let signinVC = storyboard.instantiateViewController(withIdentifier: "SigninViewController")
    self.present(signinVC, animated: true, completion: nil)


}

} 扩展HomeViewController:UITableViewDataSource {     func tableView(_ tableView:UITableView,numberOfRowsInSection section:Int) - > Int {         return posts.count

}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableview.dequeueReusableCell(withIdentifier: "imagecell", for: indexPath) as! PostCellTableViewCell
   cell.captionLabel.text = posts[indexPath.row].caption
    cell.postimage.image =  posts[indexPath.row].photoUrl
   // print(cell.captionLabel.text)
   // print(cell.daysLabel.text)


    return cell
}

}

enter code here

导入基金会 class Post {     var caption:String     var photoUrl:String

init(captiontxt: String, photoUrlString: String) {
    caption = captiontxt
    photoUrl = photoUrlString

}

}

1 个答案:

答案 0 :(得分:1)

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableview.dequeueReusableCell(withIdentifier: "imagecell", for: indexPath) as! PostCellTableViewCell

    cell.postimage.image = nil

    cell.tag += 1
    let tag = cell.tag

    cell.captionLabel.text = posts[indexPath.row].caption

    let photoUrl = posts[indexPath.row].photoUrl

    getImage(url: photoUrl) { photo in
        if photo != nil {
            if cell.tag == tag {
                DispatchQueue.main.async {
                    cell.postimage.image = photo
                }
            }
        }
    }

    return cell
}

func getImage(url: String, completion: @escaping (UIImage?) -> ()) {
    URLSession.shared.dataTask(with: URL(string: url)!) { data, response, error in
        if error == nil {
            completion(UIImage(data: data!))
        } else {
            completion(nil)
        }
    }.resume()
}