ScrollView Не прокручивает, когда появляется клавиатура. Если элементы в ContentView - PullRequest
0 голосов
/ 13 ноября 2018

У меня есть UIScrollView, в котором есть UIView (в основном просмотр содержимого).В contentView у меня есть UITextFields и UIButton.Сначала элементы находятся внутри UIScrollView напрямую.Когда клавиатура открывается, если UITextField ниже клавиатуры, прокрутка прокручивается для отображения содержимого.После того, как я поместил их в ContentView, ничего не заработало.Что я делаю неправильно?

Я искал ниже сообщения, но не уверен, почему мой код не работает.

Как прокрутить UIScrollView при появлении клавиатуры?

PS: я знаю, что есть много примеров в сообществе, но я не уверен, что будет лучшим подходом.Когда этот работал, это был простой и легкий ответ, но я не уверен, почему нет. Он не работает.

@objc override func keyboardWillShow(notification: NSNotification){
//Need to calculate keyboard exact size due to Apple suggestions
if let frameValue = notification.userInfo?[UIResponder.keyboardFrameEndUserInfoKey] as? NSValue {
    keyboardHeight = frameValue.cgRectValue.size.height

        let contentInsets = UIEdgeInsets(top: 0.0, left: 0.0, bottom: keyboardHeight, right: 0.0)
        self.scrollView.contentInset = contentInsets
        self.scrollView.scrollIndicatorInsets = contentInsets
}
}

Как я даю ограничения:

contentView.translatesAutoresizingMaskIntoConstraints = false
scrollView.addSubview(contentView)
contentView.leadingAnchor.constraint(equalTo: scrollView.leadingAnchor).isActive = true
contentView.trailingAnchor.constraint(equalTo: scrollView.trailingAnchor).isActive = true
contentView.topAnchor.constraint(equalTo: scrollView.topAnchor).isActive = true
contentView.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor).isActive = true
contentView.widthAnchor.constraint(equalTo: scrollView.widthAnchor).isActive = true
scrollView.translatesAutoresizingMaskIntoConstraints = false
self.view.addSubview(scrollView)

contentView.addSubview(TextField1)
contentView.addSubview(TextField2)
contentView.addSubview(button)
scrollView.anchor(header.bottomAnchor, left: self.view.leftAnchor, bottom: self.view.bottomAnchor, right: self.view.rightAnchor, topConstant: 20, leftConstant: 0, bottomConstant: 0, rightConstant: 0, widthConstant: 0, heightConstant: 0)
TextField1.anchor(contentView.topAnchor, left: self.contentView.leftAnchor, bottom: nil, right: self.contentView.rightAnchor, topConstant: 5, leftConstant: 25, bottomConstant: 0, rightConstant: 25, widthConstant: 0, heightConstant: 70)
TextField1.widthAnchor.constraint(equalTo: self.view.widthAnchor, constant: -50).isActive = true

TextField2.anchor(TextField1.bottomAnchor, left: self.contentView.leftAnchor, bottom: nil, right: self.contentView.rightAnchor, topConstant: 5, leftConstant: 25, bottomConstant: 0, rightConstant: 25, widthConstant: 0, heightConstant: 70)
Button.anchor(TextField2.bottomAnchor, left: self.contentView.leftAnchor, bottom: self.contentView.bottomAnchor, right: self.contentView.rightAnchor, topConstant: 30, leftConstant: 25, bottomConstant: 20, rightConstant: 25, widthConstant: 0, heightConstant: 40)

РЕДАКТИРОВАТЬ: Другой подход, который я попробовал (который Apple рекомендовал).Это aRect.Contains всегда возвращает true.

    if let frameValue = notification.userInfo?[UIResponder.keyboardFrameEndUserInfoKey] as? NSValue {
    keyboardHeight = frameValue.cgRectValue.size.height

    var contentInsets: UIEdgeInsets = UIEdgeInsets(top: 0.0, left: 0.0, bottom: keyboardHeight, right: 0.0)
    scrollView.contentInset = contentInsets
    scrollView.scrollIndicatorInsets = contentInsets

    // If active text field is hidden by keyboard, scroll it so it's visible
    // Your application might not need or want this behavior.
    //CGRect(x: 0, y: self.header.frame.maxY, width: self.view.frame.width, height: self.view.frame.height - self.header.frame.maxY)
    var aRect: CGRect = self.view.frame
    aRect.size.height -= keyboardHeight
    aRect.size.height -= header.frame.maxY
    if !aRect.contains(activeTextField.frame.origin) {
        var scrollPoint = CGPoint(x: 0.0, y: activeTextField.frame.origin.y - (keyboardHeight))
        scrollView.setContentOffset(scrollPoint, animated: true)
    }
    }

Ответы [ 2 ]

0 голосов
/ 13 ноября 2018

Простой способ добиться этого - использовать библиотеку IQKeyboardManager.

Оформить ссылку: https://github.com/hackiftekhar/IQKeyboardManager

0 голосов
/ 13 ноября 2018

После часовой работы я нахожу решение. Я делюсь ответом вместо того, чтобы удалить сообщение, потому что моя проблема была в том, что UIScrollView не содержит весь экран. Над заголовком и надписью выше UIScrollView. Все ответы в сообществе, цель Если UIScroll контента весь экран.

       @objc override func keyboardWillShow(notification: NSNotification){
    //Need to calculate keyboard exact size due to Apple suggestions
    if let frameValue = notification.userInfo?[UIResponder.keyboardFrameEndUserInfoKey] as? NSValue {
        keyboardHeight = frameValue.cgRectValue.size.height
        let scrollViewRect: CGRect = view.convert(scrollView.frame, from: scrollView.superview)
        let hiddenScrollViewRect: CGRect = scrollViewRect.intersection(frameValue.cgRectValue)

        // Figure out where the two frames overlap, and set the content offset of the scrollview appropriately
        let contentInsets: UIEdgeInsets = UIEdgeInsets(top: 0.0, left: 0.0, bottom: hiddenScrollViewRect.size.height, right: 0.0)
        scrollView.contentInset = contentInsets
        scrollView.scrollIndicatorInsets = contentInsets

        var visibleRect: CGRect = activeTextField.frame
        visibleRect = scrollView.convert(visibleRect, from: activeTextField.superview)
        visibleRect = visibleRect.insetBy(dx: 0.0, dy: -5.0)
        scrollView.scrollRectToVisible(visibleRect, animated: true)
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...