加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

swift iOS11 – 识别keyboardSize高度不再起作用

发布时间:2020-12-14 02:26:35 所属栏目:百科 来源:网络整理
导读:我刚注意到我的键盘高度识别码不再适用于iOS11. 对于iOS10设备,我使用此逻辑来检测,如果键盘将隐藏特定的输入字段(在我的情况下是文本字段).如果是这种情况,键盘将显示在最后一个活动文本字段下,以使用户能够正确输入. 对于iOS 11,键盘高度的识别不起作用.
我刚注意到我的键盘高度识别码不再适用于iOS11.

对于iOS10设备,我使用此逻辑来检测,如果键盘将隐藏特定的输入字段(在我的情况下是文本字段).如果是这种情况,键盘将显示在最后一个活动文本字段下,以使用户能够正确输入.

对于iOS 11,键盘高度的识别不起作用.

键盘的Helper类示例将显示逻辑
这只是keyBoardWillShow所做的一个例子 – >它只是检查,如果视图需要移动到键盘上方,如果键盘将隐藏文本字段.

我做了一些调试,发现下面的代码行在iOS 10和iOS 11之间的工作方式不同:

if let keyboardSize = (notification.userInfo?[UIKeyboardFrameBeginUserInfoKey] as? NSValue)?.cgRectValue

iOS10调试器输出

keyboardSize CGRect(origin =(x = 0,y = 568),size =(width = 320,height = 216))

iOS11调试器输出

keyboardSize CGRect(origin =(x = 0,height = 0))

下面你可以看到完整的代码 – 它一直工作到iOS 10.3

func keyboardWillShow(notification: NSNotification,view: UIView,activeTextField: UITextField?,scrollView: UIScrollView?) {
    if let keyboardSize = (notification.userInfo?[UIKeyboardFrameBeginUserInfoKey] as? NSValue)?.cgRectValue {
        if view.frame.origin.y == 0{
            var aRect : CGRect = (view.viewWithTag(2)?.frame)!
            aRect.size.height -= keyboardSize.height
            if let activeField = activeTextField {
                let tempPoint = CGPoint(x: activeField.frame.origin.x,y: activeField.frame.origin.y + 20)
                if (aRect.size.height < tempPoint.y){
                    view.frame.origin.y -= keyboardSize.height
                    if let scrollView = scrollView {
                        let bottomOffset = CGPoint(x: 0,y: scrollView.contentSize.height - scrollView.bounds.size.height)
                        scrollView.setContentOffset(bottomOffset,animated: true)
                    }
                }
            }
        }
    }
}

更新2017/09/20

我现在试了好几次.有时它会显示iOS11的键盘高度值 – 现在我完全糊涂了……

使用UIKeyboardFrameEndUserInfoKey代替UIKeyboardFrameBeginUserInfoKey

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读