IOS開發(fā)中鍵盤輸入屏幕上移的解決方法
在IOS開法中經(jīng)常會遇到鍵盤遮擋屏幕的事情(比如輸入賬號密碼驗證碼等等),就使得原本都不大的屏幕直接占了一半甚至更多的位置,這倒無所謂,關(guān)鍵是擋住了下面的按鈕。這樣的話按鈕的事件也就觸發(fā)不了,最好的解決辦法就是當(dāng)輸入這些信息的時候讓整個屏幕上移一個鍵盤的位置,或者上移到指定的位置。
首先一般輸入的話都用的是UITextField,所以要監(jiān)聽用戶什么時候開始輸入和什么時候結(jié)束輸入,直接設(shè)置代理代理就行了,要遵受
UITextFieldDelegate協(xié)議。
//遵循協(xié)議 @interface ViewController ()<UITextFieldDelegate> //設(shè)置屬性 @property(nonatomic,strong)UITextField* UITF; //設(shè)置代理 UITF.delegate=self; //代理方法 //鍵盤彈出時屏幕上移 -( void )textFieldDidBeginEditing:(UITextField *)textField { //假如多個輸入,比如注冊和登錄,就可以根據(jù)不同的輸入框來上移不同的位置,從而更加人性化 //鍵盤高度216 //滑動效果(動畫) NSTimeInterval animationDuration = 0.30f; [UIView beginAnimations:@ "ResizeForKeyboard" context:nil]; [UIView setAnimationDuration:animationDuration]; //將視圖的Y坐標(biāo)向上移動,以使下面騰出地方用于軟鍵盤的顯示 self.view.frame = CGRectMake(0.0f, -100.0f/*屏幕上移的高度,可以自己定*/, self.view.frame.size.width, self.view.frame.size.height); [UIView commitAnimations]; } //取消第一響應(yīng),也就是輸入完畢,屏幕恢復(fù)原狀 -( void )textFieldDidEndEditing:(UITextField *)textField { //滑動效果 NSTimeInterval animationDuration = 0.30f; [UIView beginAnimations:@ "ResizeForKeyboard" context:nil]; [UIView setAnimationDuration:animationDuration]; //恢復(fù)屏幕 self.view.frame = CGRectMake(0.0f, 0.0f, self.view.frame.size.width, self.view.frame.size.height); [UIView commitAnimations]; }
接下來說一下取消第一響應(yīng)。
一般都是在當(dāng)前View上添加一個點擊手勢即可,這樣的話就可以取消鍵盤的第一響應(yīng),但是這樣的話有一個弊端,比如:因為注冊登錄頁面當(dāng)屏幕上移時,
就會顯示注冊或登錄的頁面,如果添加點擊手勢的話那么就會覆蓋掉按鈕的點擊事件,也就是明明看到了按鈕,但是點擊卻沒反應(yīng),那么怎么辦呢?
如何實現(xiàn)注冊登錄的按鈕事件都在,點擊其他的地方還能取消鍵盤的第一響應(yīng)。
其實很簡單,我的解決辦法是這樣的
創(chuàng)建一個按鈕,和屏幕一樣大,所有的控件全部都放到這個按鈕上,而這個按鈕的點擊事件就是取消輸入框的第一響應(yīng)。這樣就可以了。
以上所述是小編給大家介紹的IOS開發(fā)中鍵盤輸入屏幕上移的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
詳解iOS App開發(fā)中session和coockie的用戶數(shù)據(jù)存儲處理
iOS在HTTP網(wǎng)絡(luò)編程環(huán)境方面提供了NSURLSession、NSHTTPCookieStorage和NSHTTPCookie類來處理session和coockie的相關(guān)內(nèi)容,接下來我們將來詳解iOS App開發(fā)中session和coockie的用戶數(shù)據(jù)存儲處理:2016-06-06iOS 控制器自定義動畫跳轉(zhuǎn)方法(模態(tài)跳轉(zhuǎn))
下面小編就為大家分享一篇iOS 控制器自定義動畫跳轉(zhuǎn)方法(模態(tài)跳轉(zhuǎn)),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01IOS實現(xiàn)微信朋友圈相冊評論界面的翻轉(zhuǎn)過渡動畫
現(xiàn)在很多人幾乎每天都離不開微信,大家有沒有發(fā)現(xiàn)在點開微信相冊的時候,想要在相冊圖片界面跳轉(zhuǎn)查看點贊和評論時,微信會采用界面翻轉(zhuǎn)的過渡動畫來跳轉(zhuǎn)到評論界面,點擊完成又會翻轉(zhuǎn)回到圖片界面,這不同于一般的導(dǎo)航界面滑動動畫,于是學(xué)著做了一下,有需要一起看看。2016-08-08iOS Tabbar中間添加凸起可旋轉(zhuǎn)按鈕功能
最近的項目中有需求在tabbar中間添加凸起按鈕,并且點擊時按鈕要旋轉(zhuǎn),看了仿斗魚的凸起,點擊后是present出來View,這篇文章主要介紹了iOS Tabbar中間添加凸起可旋轉(zhuǎn)按鈕,需要的朋友可以參考下2017-12-12iOS開發(fā)中class和#import的區(qū)別介紹
這篇文章主要介紹了iOS開發(fā)中class和#import的區(qū)別,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2018-02-02