Я пытаюсь заставить 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 выпуска