我想在从firebase接收数据后重新加载UI collectionView。现在它只在我点击刷新按钮时才能手动工作。
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()
}
}
这段代码的作用基本上是用户通过比较两个数组(身份和身份3)来显示奖牌,以确保它们相互匹配,如果不是,它将灰显不包含在数组中的身份图像(身份3)
数据在viewDidLoad中作为来自firebase的快照数据接收。我打算这样做,每次调用viewWillAppear时,collectionView都会重新加载。
我试图在viewDidLoad和viewDidAppear中调用self.collectionView!.reloadData()但无济于事。我怀疑它可能是接收数据的延迟,导致加载空白数组(identities3)。
答案 0 :(得分:3)
您需要在检索到数据并将其存储到 co_names tuple of names of local variables
co_nlocals number of local variables
后致电self.collectionView!.reloadData()
。
即在您的Firebase的{strong> DataSource
completionBlock:
.observeSingleEventOfType