Как я могу увеличить высоту inputAccessoryView

Я провел несколько дней на этом без какого-либо решения.

У меня есть inputAccessoryView, который состоит из UIView, содержащего a textView и две кнопки. Поведение inputAccessoryView соответствует ожиданиям и отлично работает во всех случаях, кроме одного.

Когда высота textView увеличивается, я пытаюсь увеличить высоту inputAccessoryView на ту же сумму. Когда я переопределяю высоту inputAccessoryView в textViewDidChange, inputAccessoryView увеличивает высоту вниз по клавиатуре, а не вверх.

Я пробовал много разных предложений от SO, но ничего не сработало. Я предполагаю, что это автоматически добавлено NSLayoutConstraint для inputAccessoryView, но я понятия не имею, как изменить это значение в swift и iOS 8.3.

func textViewDidChange(textView: UITextView) {

    var contentSize = messageTextView.sizeThatFits(CGSizeMake(messageTextView.frame.size.width, CGFloat.max))

    inputAccessoryView.frame.size.height = contentSize.height + 16

}

добавление

inputAccessoryView.setTranslatesAutoresizingMaskIntoConstraints(true)

к приведенному выше коду помогает, и высота входных данных возрастает вверх правильно, но я получаю Невозможно одновременно удовлетворить ограничения для нескольких ограничений, и очень сложно идентифицировать нарушителей. Также я получаю нечетный эффект textView, создающий дополнительное пространство ниже для каждого второго экземпляра новой строки.

спасибо.

Ответ 1

Чтобы сделать вид дополнительного аксессуара вертикальным, вы просто устанавливаете его autoresizingMask = .FlexibleHeight, вычисляете его intrinsicContentSize и позволяете структуре делать остальные.

Код:

class InputAccessoryView: UIView, UITextViewDelegate {

    let textView = UITextView()

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

        // This is required to make the view grow vertically
        self.autoresizingMask = UIViewAutoresizing.FlexibleHeight

        // Setup textView as needed
        self.addSubview(self.textView)
        self.textView.translatesAutoresizingMaskIntoConstraints = false
        self.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("H:|[textView]|", options: [], metrics: nil, views: ["textView": self.textView]))
        self.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("V:|[textView]|", options: [], metrics: nil, views: ["textView": self.textView]))

        self.textView.delegate = self

        // Disabling textView scrolling prevents some undesired effects,
        // like incorrect contentOffset when adding new line,
        // and makes the textView behave similar to Apple Messages app
        self.textView.scrollEnabled = false
    }

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

    override func intrinsicContentSize() -> CGSize {
        // Calculate intrinsicContentSize that will fit all the text
        let textSize = self.textView.sizeThatFits(CGSize(width: self.textView.bounds.width, height: CGFloat.max))
        return CGSize(width: self.bounds.width, height: textSize.height)
    }

    // MARK: UITextViewDelegate

    func textViewDidChange(textView: UITextView) {
        // Re-calculate intrinsicContentSize when text changes
        self.invalidateIntrinsicContentSize()
    }

}