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-06
iOS 控制器自定義動畫跳轉(zhuǎn)方法(模態(tài)跳轉(zhuǎn))
下面小編就為大家分享一篇iOS 控制器自定義動畫跳轉(zhuǎn)方法(模態(tài)跳轉(zhuǎn)),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
IOS實現(xiàn)微信朋友圈相冊評論界面的翻轉(zhuǎn)過渡動畫
現(xiàn)在很多人幾乎每天都離不開微信,大家有沒有發(fā)現(xiàn)在點開微信相冊的時候,想要在相冊圖片界面跳轉(zhuǎn)查看點贊和評論時,微信會采用界面翻轉(zhuǎn)的過渡動畫來跳轉(zhuǎn)到評論界面,點擊完成又會翻轉(zhuǎn)回到圖片界面,這不同于一般的導(dǎo)航界面滑動動畫,于是學(xué)著做了一下,有需要一起看看。2016-08-08
iOS Tabbar中間添加凸起可旋轉(zhuǎn)按鈕功能
最近的項目中有需求在tabbar中間添加凸起按鈕,并且點擊時按鈕要旋轉(zhuǎn),看了仿斗魚的凸起,點擊后是present出來View,這篇文章主要介紹了iOS Tabbar中間添加凸起可旋轉(zhuǎn)按鈕,需要的朋友可以參考下2017-12-12
iOS開發(fā)中class和#import的區(qū)別介紹
這篇文章主要介紹了iOS開發(fā)中class和#import的區(qū)別,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2018-02-02

