[英]Setting Scrollview's Contentsize dynamically does not work
我拼命地試圖解決這個問題,我整天都在這上面度過了運氣。 我想要做的就是有一個文本字段列表,用戶可以單擊它,它將把鍵盤放在頁面上,這樣A)該字段不會被阻塞,並且(我已經弄清楚了這部分)和B)頂部彈出鍵盤時,視圖不會被切除。 這就是我到目前為止的內容( http://imgur.com/a/LExyo ),但是您可以清楚地看到問題所在–這是我無法再向上滾動的視圖的頂部。 我試圖將整個東西埋在滾動視圖中,然后更改滾動視圖的contentsize,但是什么也沒做。 任何幫助,將不勝感激。 謝謝。 (我正在嘗試快速完成此操作3)。
class ViewController4: UIViewController, UITextFieldDelegate {
var dataState: Data?
@IBOutlet weak var UserNameLabel: UILabel!
@IBOutlet weak var TextField1Outlet: UITextField!
@IBOutlet weak var TextField2Outlet: UITextField!
@IBOutlet weak var TextField3Outlet: UITextField!
@IBOutlet weak var TextField4Outlet: UITextField!
@IBOutlet weak var TextField5Outlet: UITextField!
@IBOutlet var ViewFrame: UIView!
@IBOutlet weak var scrollView: UIScrollView!
@IBAction func TextField1Action(_ sender: Any) {
}
@IBAction func TextField2Action(_ sender: Any) {
}
@IBAction func TextField3Action(_ sender: Any) {
}
@IBAction func TextField4Action(_ sender: Any) {
}
@IBAction func TextField5Action(_ sender: Any) {
}
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
UserNameLabel.text = dataState?.LoginName
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if let destinationViewController = segue.destination as? ViewController1 {
destinationViewController.dataState = dataState
}
}
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
override func viewDidLoad() {
super.viewDidLoad()
scrollView.contentSize = CGSize(width: self.view.frame.width, height: self.view.frame.height)
scrollView.delegate = self as? UIScrollViewDelegate
TextField1Outlet.returnKeyType = UIReturnKeyType.done
TextField1Outlet.delegate = self
TextField2Outlet.returnKeyType = UIReturnKeyType.done
TextField2Outlet.delegate = self
TextField3Outlet.returnKeyType = UIReturnKeyType.done
TextField3Outlet.delegate = self
TextField4Outlet.returnKeyType = UIReturnKeyType.done
TextField4Outlet.delegate = self
TextField5Outlet.returnKeyType = UIReturnKeyType.done
TextField5Outlet.delegate = self
NotificationCenter.default.addObserver(self, selector: #selector(ViewController4.keyboardWillShow), name: NSNotification.Name.UIKeyboardWillShow, object: nil)
NotificationCenter.default.addObserver(self, selector: #selector(ViewController4.keyboardWillHide), name: NSNotification.Name.UIKeyboardWillHide, object: nil)
}
func keyboardWillShow(notification: NSNotification) {
if let keyboardSize = (notification.userInfo?[UIKeyboardFrameBeginUserInfoKey] as? NSValue)?.cgRectValue {
if self.view.frame.origin.y == 0{
self.view.frame.origin.y -= keyboardSize.height
let newHeight = self.view.frame.height + keyboardSize.height
scrollView.contentSize = CGSize(width: self.view.frame.width, height: newHeight)
}
}
}
func keyboardWillHide(notification: NSNotification) {
if let keyboardSize = (notification.userInfo?[UIKeyboardFrameBeginUserInfoKey] as? NSValue)?.cgRectValue {
if self.view.frame.origin.y != 0{
self.view.frame.origin.y += keyboardSize.height
scrollView.contentSize = CGSize(width: self.view.frame.width, height: self.view.frame.height)
}
}
}
}
使用內容插圖而不是內容大小:
scrollView.contentInset = UIEdgeInsets(top: 0.0, left: 0.0, bottom: /* keyboard height */, right: 0.0)
備份Vasilii Muravev回答您有最后一個錯誤。
第1步)
let insets = scrollView.contentInset
//Here you should save the PREVIOUS_BOTTOM
scrollView.contentInset = UIEdgeInsets(top: insets.top, left: insets.left, bottom: /* keyboard height */, right: insets.right)
第2步)
let inset = scrollViewInset.contentInset
scrollView.contentInset = UIEdgeInsets(top: inset.top, left: inset.left, bottom: PREVIOUS_BOTTOM, right: inset.right)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.