ios - uitoolbar space




_UIButtonBarStackView:becomeFirstResponderが送信されたときの制約を破る (2)

あるテキストフィールドから別のテキストフィールドにジャンプするときは、次のようにします。

translatesAutoresizingMaskIntoConstraints) 
(
    "<NSAutoresizingMaskLayoutConstraint:0x6040002806e0 UIKeyboardAssistantBar:0x7f986d40d020.height == 0>",
    "<NSLayoutConstraint:0x60400008ece0 _UIButtonBarStackView:0x7f986d4041c0.top == UIKeyboardAssistantBar:0x7f986d40d020.top>",
    "<NSLayoutConstraint:0x60400008ed30 UIKeyboardAssistantBar:0x7f986d40d020.bottom == _UIButtonBarStackView:0x7f986d4041c0.bottom>",
    "<NSLayoutConstraint:0x60400009f220 _UIButtonBarButton:0x7f986d438480.height == UILayoutGuide:0x6040005b5ee0.height>",
    "<NSLayoutConstraint:0x60400008e1a0 _UIButtonBarStackView:0x7f986d4041c0.bottom == UILayoutGuide:0x6040005b5ee0.bottom + 9>",
    "<NSLayoutConstraint:0x60400008e100 UILayoutGuide:0x6040005b5ee0.top == _UIButtonBarStackView:0x7f986d4041c0.top + 10>"
)

Will attempt to recover by breaking constraint 
<NSLayoutConstraint:0x60400008e1a0 _UIButtonBarStackView:0x7f986d4041c0.bottom == UILayoutGuide:0x6040005b5ee0.bottom + 9>

Make a symbolic breakpoint at UIViewAlertForUnsatisfiableConstraints to catch this in the debugger.
The methods in the UIConstraintBasedLayoutDebugging category on UIView listed in <UIKit/UIView.h> may also be helpful.

シミュレータでテストして、デバイスに乗らないでください。 キーボード1の上のショートカットバーに問題がありますか?

私の非常に簡単なコードは、制約を破ります。

-(BOOL)textFieldShouldReturn:(UITextField*)textField
{
    [textField resignFirstResponder];

    if (textField.tag > 0) {

        UITextField *nextTextField = [self.view viewWithTag:textField.tag+1];
        [nextTextField becomeFirstResponder];
    }

    return YES;
}

ここでも同じ問題です。 私はかなりのテキストフィールドを持っているので、私はビュー内のすべてのUITextFieldを '修正'する次のような拡張をしました。

extension UIView
{
    func fixInputAssistant()
    {
        for subview in self.subviews
        {
            if type(of: subview) is UITextField.Type
            {
                let item = (subview as! UITextField).inputAssistantItem
                item.leadingBarButtonGroups = []
                item.trailingBarButtonGroups = []
            }
            else if subview.subviews.count > 0
            {
                subview.fixInputAssistant()
            }
        }
    }
}

ViewControllerでの使用方法:

override func viewDidLoad()
{   
    super.viewDidLoad()
    view.fixInputAssistant()
    ...
}

この警告はかなり長い間私を悩ませてきました。 UITextFieldのinputAssistantItemプロパティで、 leadingBarButtonGroupstrailingBarButtonGroupsを空にすることで、2行のハックを発見しました。

inputAssistantItem.leadingBarButtonGroups = []
inputAssistantItem.trailingBarButtonGroups = []

これは呼び出し時のUIKeyboardAssistantBar AutoLayout警告を制御します

becomeFirstResonder()

ここでより多くの情報: https : //developer.apple.com/documentation/uikit/uitextinputassistantitem

アップルからの具体的なメモ:

ショートカットを完全に隠すには、leadingBarButtonGroupsプロパティとtrailingBarButtonGroupsプロパティをnilに設定します。





becomefirstresponder