繁体   English   中英

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

[英]How do I prevent Keyboard from adding its own height constraint when using view as inputAccessoryView

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

不幸的是,这是一个定义其自身高度的动态视图。 约束在附件视图的上下文之外都可以正常工作,没有错误,并且可以正确调整大小

当添加为keyboardAccessoryView时,它似乎会强加当时框架的高度并打破其他高度限制

它显示为:

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

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

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

试过:

inputAccessoryView覆盖中,我尝试检查约束并将其删除,但此时它不存在

设置translatesAutoresizing...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()
        }
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM