UITextField не перемещается в правильное местоположение с помощью запуска клавиатуры - PullRequest
1 голос
/ 22 января 2020

Я пытаюсь заставить UITextField переместиться так, чтобы он располагался поверх клавиатуры (так же, как iMessage), но не могу понять, в чем моя проблема. Я рассмотрел вопросы, подобные этому, но до сих пор безуспешно. Текстовое поле, кажется, немного смещается, но заканчивается за клавиатурой, так что, надеюсь, это глупая проблема размещения координат, на которую кто-то может указать мне. Еще одна вещь, на которую следует обратить внимание, это то, что GIF ниже находится на iPhone X, однако, когда я запускаю приложение на iPhone 6, UITextField перемещается в правильное положение над клавиатурой, но перемещается обратно под ним, как только я введите что-нибудь. Любая помощь приветствуется!

class ChatViewController: UIViewController {

@IBOutlet weak var messageView: UIView!
@IBOutlet weak var collectionView: UICollectionView!
@IBOutlet weak var textMessageField: UITextField!
@IBOutlet weak var contactStatusLabel: UILabel!
@IBOutlet weak var sendButton: UIButton!
@IBOutlet weak var videoChatButton: UIButton!
let cellID = "cellID"
var contactIsOnline = false
var currentUser:G8User = G8User()
var currentContact:G8User = G8User()
var currentConversation : Conversation?
var videoToken = ""
var allMessages : [ChatMessage] = []
var onlineRef:DatabaseReference!
var incomingMessagesRef:DatabaseReference!


override func viewDidLoad() {
    super.viewDidLoad()
    sendButton.backgroundColor = UIColor(red: CGFloat(0/255), green: CGFloat(137.0/255.0), blue: CGFloat(249.0/255.0), alpha: 1)
    sendButton.layer.cornerRadius = 5
    videoChatButton.backgroundColor = UIColor.red
    videoChatButton.layer.cornerRadius = 5
    collectionView.alwaysBounceVertical = true
    collectionView.contentInset = UIEdgeInsets(top: 10, left: 0, bottom: 10, right: 0)
    collectionView.scrollIndicatorInsets = UIEdgeInsets(top: 10, left: 0, bottom: 10, right: 0)
    collectionView.register(ChatMessageCell.self, forCellWithReuseIdentifier: cellID)
    collectionView.dataSource = self
    collectionView.delegate = self

    // Used to dismiss keyboard
    let tap = UITapGestureRecognizer(target: self.view, action: #selector(UIView.endEditing(_:)))
    tap.cancelsTouchesInView = false
    self.view.addGestureRecognizer(tap)



    // Set up keyboard observers
    NotificationCenter.default.addObserver(self, selector: #selector(ChatViewController.keyboardWillShow), name: UIResponder.keyboardWillShowNotification, object: nil)
    NotificationCenter.default.addObserver(self, selector: #selector(ChatViewController.keyboardWillHide), name: UIResponder.keyboardWillHideNotification, object: nil)


}

 @objc func keyboardWillShow(notification: NSNotification) {
    print("SHOWING KEYBOARD")
     // TODO: Adjust scrolling for message view
     if let keyboardFrame = (notification.userInfo?[UIResponder.keyboardFrameEndUserInfoKey] as? NSValue)?.cgRectValue{

        let topOfMessageBox = keyboardFrame.origin.y - self.messageView.frame.height
         self.collectionView.frame = CGRect(x: collectionView.frame.origin.x,y: collectionView.frame.origin.y,width: collectionView.frame.width,height: topOfMessageBox - collectionView.frame.origin.y)
        self.messageView.frame = CGRect(x: messageView.frame.origin.x,y: topOfMessageBox,width: messageView.frame.width, height: messageView.frame.height)


     }
 }

 @objc func keyboardWillHide(notification: NSNotification) {
    print("HIDING KEYBOARD")

    self.collectionView.frame = CGRect(x: collectionView.frame.origin.x,y: collectionView.frame.origin.y,width: collectionView.frame.width,height:  messageView.frame.origin.y - collectionView.frame.origin.y )
    self.messageView.frame = CGRect(x: messageView.frame.origin.x,y: self.view.frame.maxY - messageView.frame.size.height,width: messageView.frame.width,height: messageView.frame.height)
 }

GIF выпуска

1 Ответ

1 голос
/ 22 января 2020

Попробуйте это UIView расширение что-то вроде myTextField.bindToKeyboard()

extension UIView {

    func bindToKeyboard() {

        NotificationCenter.default.addObserver(self, selector: #selector(keyboardWillChange(_:)), name: UIResponder.keyboardWillChangeFrameNotification, object: nil)
    }

    @objc func keyboardWillChange(_ notification: NSNotification) {

        let duration = notification.userInfo![UIResponder.keyboardAnimationDurationUserInfoKey] as! Double
        let curve = notification.userInfo![UIResponder.keyboardAnimationCurveUserInfoKey] as! UInt
        let beginningFrame = (notification.userInfo![UIResponder.keyboardFrameBeginUserInfoKey] as! NSValue).cgRectValue
        let endFrame = (notification.userInfo![UIResponder.keyboardFrameEndUserInfoKey] as! NSValue).cgRectValue
        var deltaY = endFrame.origin.y - beginningFrame.origin.y

        UIView.animateKeyframes(withDuration: duration, delay: 0.0, options: UIView.KeyframeAnimationOptions(rawValue: curve), animations: {
            self.frame.origin.y += deltaY
        }, completion: nil)
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...