Реализация представления коллекции с настраиваемым заголовком для каждой второй строки - PullRequest
0 голосов
/ 30 марта 2019

Я пытаюсь создать представление коллекции, в котором заголовок реализован с изображением в каждой строке с 5 ячейками коллекции в ряду между ними, например:

enter image description here

В данный момент я настраиваю это с помощью следующего кода:

Класс представления заголовка:

class HeaderView: UICollectionReusableView {

let imageView: UIImageView = {
    let image = UIImage.init(named: "trophyCase")
    let iv = UIImageView(image: image)
    iv.clipsToBounds = true
    iv.contentMode = .scaleAspectFill
    return iv
}()

override init(frame: CGRect) {
    super.init(frame: frame)
    backgroundColor = .white
    addSubview(imageView)
    imageView.fillSuperview()
}


required init?(coder aDecoder: NSCoder) {
    fatalError("init(coder:) has not been implemented")
}

}

ViewController:

class TrophyListViewController: UICollectionViewController{

fileprivate let headerId = "headerId"
var headerView: HeaderView?

override func viewDidLoad() {
    super.viewDidLoad()
    collectionView.register(HeaderView.self, forSupplementaryViewOfKind: UICollectionView.elementKindSectionHeader, withReuseIdentifier: headerId)

}

override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    return 5
}

override func numberOfSections(in collectionView: UICollectionView) -> Int {
    return progressAchievements.count / 5 
}

override func collectionView(_ collectionView: UICollectionView, viewForSupplementaryElementOfKind kind: String, at indexPath: IndexPath) -> UICollectionReusableView {
    headerView = collectionView.dequeueReusableSupplementaryView(ofKind: kind, withReuseIdentifier: headerId, for: indexPath) as? HeaderView
    return headerView!
}

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, referenceSizeForHeaderInSection section: Int) -> CGSize {
    return .init(width: view.frame.width, height: 340)
}

override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "trophyCell", for: indexPath) as! TrophyListCell


    //achievementImage
    cell.trophyImage.image = UIImage(named:progressAchievements[indexPath.row][1])
    cell.trophyImage.frame = CGRect(x:12, y:11, width:100, height:100)


    return cell
}

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
    let wid = ( collectionView.frame.width - 20 ) / 5
    return CGSize(width:wid,height:160)
}

}

Расширение UIView:

extension UIView {
func fillSuperview(withPadding padding: UIEdgeInsets = .zero) {
    translatesAutoresizingMaskIntoConstraints = false
    if let superview = superview {
        topAnchor.constraint(equalTo: superview.topAnchor, constant: padding.top).isActive = true
        leftAnchor.constraint(equalTo: superview.leftAnchor, constant: padding.left).isActive = true
        rightAnchor.constraint(equalTo: superview.rightAnchor, constant: -padding.right).isActive = true
        bottomAnchor.constraint(equalTo: superview.bottomAnchor, constant: -padding.bottom).isActive = true
    }
}

}

Когда я иду тестировать код, появляются все разделы, но мне не хватает заголовков для каждой строки, и только 3 ячейки появляются для каждой строки.Я чувствую, что близок к этому, но мог бы помочь кому-то объяснить, где я ошибся здесь.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...