我想让UI collectionView在从firebase接收到数据后重新加载自己。现在它只在我单击刷新按钮时手动工作。
class MedalsViewController: UICollectionViewController {
var imagesArray = [String]()
var identities = [String]()
var identities2 = [String]() //Creates an empty array
var imagesArrayGreyed = [String]()
var identities3 = [String]()
let databaseRef = FIRDatabase.database().reference()
let userID = FIRAuth.auth()?.currentUser?.uid
override func viewDidLoad() {
super.viewDidLoad()
let userID = FIRAuth.auth()?.currentUser?.uid
let databaseRef = FIRDatabase.database().reference()
databaseRef.child("users").child(userID!).child("medals").observeSingleEventOfType(.Value, withBlock: { (snapshot) in
// Get user medals
self.identities3 = snapshot.value as! [String]
print (self.identities3)
})
imagesArray = ["1", "2", "3"] //Add all the medal images here
identities = ["Shield", "Tie", "Star"] //Add all the identities here
identities2 = ["Shield", "Tie"] //Choose what medals the user has.
imagesArrayGreyed = ["1Greyed","2Greyed","3Greyed"] //Add all the greyed images here
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
override func viewWillAppear(animated: Bool) {
self.tabBarController?.tabBar.hidden = false
// Attempt at getting medals array from firebase database
}
override func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCellWithReuseIdentifier("cell", forIndexPath: indexPath)
let imageView = cell.viewWithTag(1) as! UIImageView
// Identites2 is the medals you currently own, so it'll check back to see if you own the medal and if not a question mark will be displayed.
// Time to check to see if it can update in real time. Check out firebase and try to link it here
// Also see if can add a progress bar to only show for those greyed out medals
// Get ready to edit this to identities3 which is directly taken from firebase database
if (identities3.contains(identities[indexPath.row])) {
imageView.image = UIImage(named: imagesArray[indexPath.row])
}
else {
imageView.image = UIImage(named: imagesArrayGreyed[indexPath.row]) //Set default image not in identities2
}
return cell
}
override func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return imagesArray.count
}
override func collectionView(collectionView: UICollectionView, didSelectItemAtIndexPath indexPath: NSIndexPath) {
let vc = identities[indexPath.row]
let viewController = storyboard?.instantiateViewControllerWithIdentifier(vc)
self.navigationController?.pushViewController(viewController!, animated: true)
viewController?.title = self.identities[indexPath.row]
}
// Send a fake medal from the array of identities2
@IBAction func sendFakeMedalandReload(sender: UIBarButtonItem) {
let databaseRef = FIRDatabase.database().reference()
databaseRef.child("users/\(FIRAuth.auth()!.currentUser!.uid)/medals").setValue(identities2)
self.collectionView!.reloadData()
}
}
这段代码主要是通过比较两个数组(identities和identities3)来显示用户拥有的奖牌,以确保它们是一致的,否则它将灰显数组中没有包含的identities3的标识图像
在viewDidLoad中,数据作为来自firebase的快照数据接收。我打算让collectionView在每次调用viewWillAppear时重新加载。
我试图调用self.collectionView!viewDidLoad和viewdid中的.reloadData()出现,但无效。我怀疑可能是由于接收数据的延迟导致加载空白数组(identies3)。
最佳答案
在检索到数据并将其存储到self.collectionView!.reloadData()
中之后,您需要调用DataSource
。
也就是说在你的Firebase的completionBlock:
中
databaseRef.child("users").child(userID!).child("medals").observeSingleEventOfType(.Value, withBlock: { (snapshot) in
// Get user medals
self.identities3 = snapshot.value as! [String]
self.collectionView!.reloadData()
})
关于swift - uicollectionview从Firebase接收数据后如何重新加载?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/39560165/