ячейка для самостоятельного определения размера с помощью uitableviewdiffabledatasource

#ios #swift #uitableview #uikit #uitableviewdiffabledatasource

#iOS #swift #uitableview #uikit #uitableviewdiffabledatasource

Вопрос:

У меня есть подробный ViewController, ячейки которого определяются пользовательскими uitableviewdiffabledata, подобными этому:

 { (_, indexPath, item) -> UITableViewCell? in
            let color = UIColor(named: "blue")!
            if let _ = item as? TextFieldItem, let cell = tableView.dequeueReusableCell(withIdentifier: "textField", for: indexPath) as? TextFieldTableViewCell {
                cell.textField.text = recipe.wrappedValue.name
                cell.textField.placeholder = NSLocalizedString("name", comment: "")
                cell.selectionStyle = .none
                cell.textChanged = nameChanged
                cell.backgroundColor = color
                return cell
            } else if let imageItem = item as? ImageItem, let imageCell = tableView.dequeueReusableCell(withIdentifier: "image", for: indexPath) as? ImageTableViewCell {
                imageCell.setup(imageData: imageItem.imageData)
                return imageCell
            } else if let _ = item as? AmountItem, let amountCell = tableView.dequeueReusableCell(withIdentifier: "times", for: indexPath) as? AmountTableViewCell{
                amountCell.setUp(with: recipe.wrappedValue.timesText, format: formatAmount)
                amountCell.backgroundColor = color
                return amountCell
            } else if item is InfoItem {
                return  InfoTableViewCell(infoText: Binding(get: {
                    return recipe.wrappedValue.info
                }, set: updateInfo), reuseIdentifier: "info")
            } else if let stripItem = item as? InfoStripItem, let infoStripCell = tableView.dequeueReusableCell(withIdentifier: "infoStrip", for: indexPath) as? InfoStripTableViewCell {
                infoStripCell.setUpCell(for: stripItem)
                return infoStripCell
            } else if let stepItem = item as? StepItem {
                let stepCell = StepTableViewCell(style: .default, reuseIdentifier: "step")
                stepCell.setUpCell(for: stepItem.step)
                return stepCell
            } else if let detailItem = item as? DetailItem, let cell = tableView.dequeueReusableCell(withIdentifier: "detail", for: indexPath) as? DetailTableViewCell {
                let title = NSAttributedString(string: detailItem.text, attributes: [.foregroundColor : UIColor.label])
                cell.textLabel?.attributedText = title
                cell.accessoryType = .disclosureIndicator
                cell.backgroundColor = color
                return cell
            }
            return UITableViewCell()
        }
  

и я хочу создать InfoTableViewCell, которая определяется следующим образом:

 class InfoTableViewCell: UITableViewCell {
    @Binding private var infoText: String
    
    private var textView = UITextView()

    init(infoText: Binding<String>, reuseIdentifier: String?) {
        self._infoText = infoText
        super.init(style: .default, reuseIdentifier: reuseIdentifier)
        setup()
    }
    
    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
    
    private func setup() {
        self.addSubview(textView)
        textView.fillSuperview()
        
        
        textView.text = infoText
        textView.delegate = self
        
        textView.backgroundColor = UIColor(named: "blue")!
        textView.font = UIFont.preferredFont(forTextStyle: .body)
    }
    
}

extension InfoTableViewCell: UITextViewDelegate {
    
    func textViewDidChange(_ textView: UITextView) {
        self.infoText = textView.text
    }
    
}
  

и я хочу изменить размер этой ячейки на основе текста, который находится в текстовом поле. Есть какие-нибудь советы о том, как это сделать?
P. S. Я использую инструменты LBTA для заполнения содержимого ячейки текстовым полем.

Ответ №1:

По моему опыту, просто опустите tableView(_:heightForRowAt:) делегат tableview. Затем при создании ваших ячеек создайте ограничения, которые привязывают верхнюю и нижнюю части вашей ячейки к верхней и нижней части вашего содержимого. Затем ячейка будет увеличиваться или сжиматься в соответствии с ограничениями.

В init вашем пользовательском классе ячеек табличного представления:

 textView.topAnchor.constraint(equalTo: self.topAnchor, constant: 8).isActive = true
textView.bottomAnchor.constraint(equalTo: self.bottomAnchor, constant: -8).isActive = true
  

Не уверен, как инструменты LBTA повлияют на поведение этого, так что это может работать только с ванильным UIKit.