如何防止键盘在使用视图作为inputAccessoryView时添加自己的高度约束?



我正在尝试使用自定义视图作为键盘上的附属视图,出于各种原因,在这种情况下,由于其他一些功能,它比手动键盘对齐更受欢迎。

不幸的是,这是一个动态视图,它定义了自己的高度。在accessoryView的上下文之外,约束都可以正常工作,没有错误,并且可以正确地调整

的大小。当作为keyboardAccessoryView添加时,它似乎强加了一个框架的高度,无论当时是什么,并打破了其他高度限制

显示为:

"<NSLayoutConstraint:0x600003e682d0 '_UIKBAutolayoutHeightConstraint' Turntable.ChatInput:0x7fb629c15050.height == 0   (active)>"

(其中0对应于初始化时使用的高度)

它也被标记为accessoryHeight,这应该很容易删除,但不幸的是,在我能做到这一点之前,我得到了不满意的约束,系统抛出了我的高度约束

尝试:

inputAccessoryView覆盖,我试图检查约束并删除它,但它不存在在这个时候

settingtranslatesAutoresizing...Constraints = false

tl;博士

使用一个视图作为一个KeyboardAccessoryView是添加自己的高度约束后的事实,我可以删除这个?

看起来键盘不像inputAccessoryView的高度限制。然而,您仍然可以使用frame使用inputAccessoryView动态高度(仍然可以在中使用约束)。您的自定义inputAccessoryView).

请检查这个例子:

import UIKit
final class ViewController: UIViewController {
private let textField: UITextField = {
let view = UITextField()
view.frame = .init(x: 100, y: 100, width: 200, height: 40)
view.borderStyle = .line
return view
}()
private let customView: UIView = {
let view = UIView()
view.backgroundColor = .red
view.frame.size.height = 100
view.autoresizingMask = .flexibleHeight // without this line height won't change
return view
}()
override func viewDidLoad() {
super.viewDidLoad()
view.addSubview(textField)
textField.inputAccessoryView = customView
textField.becomeFirstResponder()
DispatchQueue.main.asyncAfter(deadline: .now() + 3) {
self.customView.frame.size.height = 50
self.textField.reloadInputViews()
}
}
}

最新更新