Динамический размер CollectionViewCells - PullRequest
0 голосов
/ 25 сентября 2018

У меня есть макет, который использует несколько ячеек коллекции, чтобы выложить себя.В данный момент я использую статическую высоту, но, как мы все знаем, невозможно сказать, какой размер содержимого будет особенно в моем случае, потому что текст будет занимать большую часть ячейки.Я не смог найти способ точного определения размера ячейки исходя из размера textView в ячейке вместе с отступом.

Итак, вкратце я спрашиваю, есть ли в любом случае размерсодержимое основано на размере вещей в коллекции.

Это то, что у меня есть для ячейки

import UIKit

class DetailCell: UICollectionViewCell {

    var eventDescription: String? {
        didSet{
            print("got description")
            guard let eventDescription = eventDescription else {
                return
            }
            eventDetails.text = eventDescription
            updateWithSpacing(lineSpacing: 10.0)
            textViewDidChange(eventDetails)

        }
    }




    lazy var eventDetails: UITextView = {
        let textView = UITextView()
        guard let customFont = UIFont(name: "NoirPro-SemiBold", size: 15) else {
            fatalError("""
        Failed to load the "CustomFont-Light" font.
        Make sure the font file is included in the project and the font name is spelled correctly.
        """
            )
        }
        textView.font = customFont
        textView.textColor = UIColor.rgb(red: 32, green: 32, blue: 32)
        textView.textContainer.maximumNumberOfLines = 0
        textView.isScrollEnabled = false
        textView.isEditable = false
        textView.textAlignment = .natural
        return textView
    }()


    override init(frame: CGRect) {
        super.init(frame: frame)
        setupViews()
    }

    fileprivate func setupViews(){
        addSubview(eventDetails)
        eventDetails.delegate = self

        eventDetails.snp.makeConstraints {
            make in
            make.top.equalTo(detailsLabel.snp.bottom).offset(15)
            make.left.right.equalTo(self).inset(5)
            make.height.equalTo(50)
        }

    }

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


    //MARK: - Update Line Spacing
    func updateWithSpacing(lineSpacing: Float) {
        // The attributed string to which the
        // paragraph line spacing style will be applied.
        let attributedString = NSMutableAttributedString(string: eventDetails.text!)
        let mutableParagraphStyle = NSMutableParagraphStyle()
        // Customize the line spacing for paragraph.
        mutableParagraphStyle.lineSpacing = CGFloat(lineSpacing)
        mutableParagraphStyle.alignment = .justified
        if let stringLength = eventDetails.text?.count {
            attributedString.addAttribute(NSAttributedStringKey.paragraphStyle, value: mutableParagraphStyle, range: NSMakeRange(0, stringLength))
        }
        // textLabel is the UILabel subclass
        // which shows the custom text on the screen
        eventDetails.attributedText = attributedString

    }

}

extension DetailCell: UITextViewDelegate {
    func textViewDidChange(_ textView: UITextView) {
        print(textView.text)
        let size = CGSize(width: self.frame.width - 5, height: .infinity)
        let estimatedSize = textView.sizeThatFits(size)
        textView.constraints.forEach { (constraint) in
            if constraint.firstAttribute == .height {
                constraint.constant = estimatedSize.height
            }
        }
    }

}

Это мой размер ячейки.

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
        return CGSize(width: collectionView.frame.width, height: 350.0)
}

Любая помощь будет оценена

1 Ответ

0 голосов
/ 25 сентября 2018

Вы можете узнать высоту ячейки как

extension String {
func height(withConstrainedWidth width: CGFloat, font: UIFont?) -> CGFloat {
    guard let fontValue = font else {
        return 0
    }
    let constraintRect = CGSize(width: width, height: .greatestFiniteMagnitude)
    let boundingBox = self.boundingRect(with: constraintRect,
                                        options: .usesLineFragmentOrigin,
                                        attributes: [NSFontAttributeName: fontValue],
                                        context: nil)
    if boundingBox.height >= 80 {
       return 80
    }
    return ceil(boundingBox.height)
 }
}

, после чего вы можете использовать это расширение строки, чтобы получить значение высоты и передать его делегату collectionView

func collectionView(_ collectionView: UICollectionView,
                    layout collectionViewLayout: UICollectionViewLayout,
                    sizeForItemAt indexPath: IndexPath) -> CGSize {
    let feature = cellData.arrayOfData[indexPath.row]
    let height = feature.height(withConstrainedWidth: collectionView.frame.width,
                                font:"FontYouAddedToTextView")
    return CGSize(width: collectionView.frame.width, height: height)
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...