Второй UICollectionView не перезагружается - PullRequest
0 голосов
/ 01 июня 2018

Я пытаюсь реализовать два UICollectionView в одном и том же UIViewController.Однако все идет не так, когда я запускаю приложение, появляется только один UICollectionView, а другой просто остается пустым.Я пробовал много способов исправить это, но я всегда заканчиваю с ошибкой.

import UIKit

class ViewController: UIViewController, UICollectionViewDataSource {

    @IBOutlet var collectionView: UICollectionView!
    @IBOutlet weak var collectionViewBanner: UICollectionView!


    var dataSource: [Content] = [Content]()
    var dataBanner: [Banner] = [Banner]()

    override func viewDidLoad() {
        super.viewDidLoad()

        getBanner { (data) in
            DispatchQueue.main.async {
                self.dataBanner = data
                self.collectionViewBanner.reloadData()
            }
        }


        getAudiobooksAPI { (data) in
            DispatchQueue.main.async {
                self.dataSource = data
                self.collectionView.reloadData()
            }
        }
    }

    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        if self.collectionView.tag == 1 {
            return  self.dataSource.count
        } else {
            return self.dataBanner.count
        }
    }

    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {

        if (collectionView == self.collectionView) {
            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "collectionViewCell", for: indexPath) as! CollectionViewCell

            let content = self.dataSource[indexPath.item]

            cell.bookLabel.text = content.descricao
            cell.bookImage.setImage(url: content.urlImagem, placeholder: "")

            return cell

        } else if (collectionView == self.collectionViewBanner) {

            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "collectionViewCellBanner", for: indexPath) as! CollectionViewCell

            let content = self.dataBanner[indexPath.item]

            cell.bannerImage.setImage(url: content.urlImagem, placeholder: "")

            return cell
        }
        return UICollectionViewCell()
    }

}

extension UIImageView {
    func setImage(url : String, placeholder: String, callback : (() -> Void)? = nil){
        self.image = UIImage(named: "no-photo")

        URLSession.shared.dataTask(with: NSURL(string: url)! as URL, completionHandler: { (data, response, error) -> Void in

            guard error == nil else {
                return
            }
            DispatchQueue.main.async(execute: { () -> Void in
                let image = UIImage(data: data!)
                self.image = image
                if let callback = callback{
                    callback()
                }                    
            })

        }).resume()
    }
}

Другой UICollectionView должен появиться над этим.Что я делаю не так?

Изображение запуска приложения

enter image description here

[EDIT] Я отлаживаю код и ставлю точку останова на этих строках.Итак, случилось то, что компилятор просто прочитал «если», а не вошел «в другое».

func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    if self.collectionView.tag == 1 {
        return  self.dataSource.count
    } else {
        return self.dataBanner.count
    }
}

Ответы [ 3 ]

0 голосов
/ 01 июня 2018
getBanner { (data) in
        DispatchQueue.main.async {
        self.dataBanner = data
        self.collectionViewBanner.reloadData()
        }
    }


    getAudiobooksAPI { (data) in
        DispatchQueue.main.async {
            self.dataSource = data
            self.collectionView.reloadData()
        }
    }


   func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    if (collectionView == self.collectionView) { 
       return self.dataSource.count 
    }else if (collectionView == self.collectionViewBanner) { 
       return self.dataBanner.count 
    } else { 
       return nil 
    } 
}
0 голосов
/ 01 июня 2018

Пожалуйста, используйте Мой код, это решит вашу проблему

Первое изменение

Первое изменение в коллекцииViewBanner.reloadData

Второе изменение

Просто проверьте метод NumberofiteminSection

import UIKit

class ViewController: UIViewController, UICollectionViewDataSource {

    @IBOutlet var collectionView: UICollectionView!
    @IBOutlet weak var collectionViewBanner: UICollectionView!


    var dataSource: [Content] = [Content]()
    var dataBanner: [Banner] = [Banner]()

    override func viewDidLoad() {
        super.viewDidLoad()

        getBanner { (data) in
            DispatchQueue.main.async {
            self.dataBanner = data
            self.collectionViewBanner.reloadData()
            }
        }


        getAudiobooksAPI { (data) in
            DispatchQueue.main.async {
                self.dataSource = data
                self.collectionView.reloadData()
            }
        }
    }

    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        if (collectionView == self.collectionView) {
        return  self.dataSource.count
        }else{

        return self.dataBanner.count
        }
    }

    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {

        if (collectionView == self.collectionView) {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "collectionViewCell", for: indexPath) as! CollectionViewCell

        let content = self.dataSource[indexPath.item]

        cell.bookLabel.text = content.descricao
        cell.bookImage.setImage(url: content.urlImagem, placeholder: "")

        return cell

        }else if (collectionView == self.collectionViewBanner) {

            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "collectionViewCellBanner", for: indexPath) as! CollectionViewCell

            let content = self.dataBanner[indexPath.item]

            cell.bannerImage.setImage(url: content.urlImagem, placeholder: "")


            return cell
        }
        return UICollectionViewCell()
    }

}

extension UIImageView{
    func setImage(url : String, placeholder: String, callback : (() -> Void)? = nil){
        self.image = UIImage(named: "no-photo")

        URLSession.shared.dataTask(with: NSURL(string: url)! as URL, completionHandler: { (data, response, error) -> Void in

            guard error == nil else{
                return
            }
            DispatchQueue.main.async(execute: { () -> Void in
                let image = UIImage(data: data!)
                self.image = image
                if let callback = callback{
                    callback()
                }


            })

        }).resume()
    }
}
0 голосов
/ 01 июня 2018

Вы забыли перезагрузить collectionViewBanner .просто

collectionViewBanner.reloadData()
...