總結(jié)IOS關(guān)閉鍵盤/退出鍵盤的五種方式
話不多說,接下來就是幾種實現(xiàn)方式:
1,點擊編輯區(qū)以外的地方(UIView)
這是一種很直覺的方法,當(dāng)不再需要使用虛擬鍵盤時,只要點擊虛擬鍵盤和編輯區(qū)域外的地方,就可以將鍵盤收起,下面程式碼是在 UIView
中內(nèi)建的觸碰事件方法函式,您可以參考 Touch Panel / 觸碰螢?zāi)?/ 壓力感應(yīng)器的基本使用方式一文,找到更多關(guān)于觸碰事件的方法函式。
– (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event { if (![myTextView isExclusiveTouch]) { [myTextView resignFirstResponder]; } }
如果要使用此方式請務(wù)必記得,你操作畫面的 Custom Class 一定要是 UIView 才行。
畫面的 Custom Class 為 UIView
2. 點擊編輯區(qū)域以外的地方(UIControl)
收起虛擬鍵盤的方式與前一種相同,但是如果你的觸碰事件里已經(jīng)且寫滿了程式碼,那么就可以考慮使用,UIControl 的 Touch Up Inside 事件來收起鍵盤,方法是將以下程式碼與 UIControl 的 Touch Up Inside 事件連結(jié)即可。
– (IBAction)dismissKeyboard:(id)sender { [myTextView resignFirstResponder]; }
如果要使用此方式請務(wù)必記得,你操作畫面的 Custom Class 一定要是 UIControl 才行。
畫面的 Custom Class 為 UIControl
將收起鍵盤的方法與 UIControl 事件連結(jié)
3. 使用制作收起鍵盤的按鈕
當(dāng)沒有編輯區(qū)域以外的地方可供點擊來收起鍵盤,自己制作一個按鈕來收起目前的虛擬鍵盤,也是一個不錯的方法,由于按鈕必須在虛擬鍵盤出現(xiàn)才能顯示于畫面上,因此必須借用 NSNotificationCenter 來幫助我們判斷目前鍵盤的狀態(tài)。
首先在 viewDidLoad:
事件中,向 NSNotificationCenter 進行註冊,告訴 NSNotificationCenter 我們的 doneButtonshow:
方法函式。
– (void)viewDidLoad { [super viewDidLoad]; [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector (doneButtonshow:) name: UIKeyboardDidShowNotification object:nil]; }
現(xiàn)在每當(dāng)虛擬鍵盤出現(xiàn)時,就會自動呼叫我們自定義的 doneButtonshow:
方法函式,接下來只要在該方法函式里定義按鈕出現(xiàn)的方法即可。
-(void) doneButtonshow: (NSNotification *)notification { doneButton = [UIButton buttonWithType: UIButtonTypeRoundedRect]; doneButton.frame = CGRectMake(0, 228, 70, 35); [doneButton setTitle:@”完成編輯” forState: UIControlStateNormal]; [doneButton addTarget: self action:@selector(hideKeyboard) forControlEvents: UIControlEventTouchUpInside]; [self.view addSubview:doneButton]; }
最后是實作按鈕按下去時的 hideKeyboard:
方法函式,務(wù)必記得要在函式中移除該按鈕。
-(void) hideKeyboard { [doneButton removeFromSuperview]; [myTextView resignFirstResponder]; }
4. 使用判斷輸入字元
如果要使用輸入特定字元(例如 return
換行字元)來收起鍵盤,必須先在類別內(nèi)的 @interface
區(qū)段採用 協(xié)定,您可以參考 Protocol 協(xié)定的使用方式一文,獲得更多關(guān)于協(xié)定的資訊。
在采用 協(xié)定之后,接著實作出協(xié)定內(nèi)的 textView:shouldChangeTextInRange:replacementText:
方法函式,此方法函式會在字元輸入時觸發(fā),而回傳的 BOOL
值則代表該字元是否要作用,下列程式碼就是在此方法函式中,使用判斷輸入字元的方式來收起虛擬鍵盤(判斷字元為 return
換行字元)。
– (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text { if () { [myTextView resignFirstResponder]; return NO; } return YES; }
最后別忘記在 viewDidLoad:
事件中,將 UITextView
的代理物件指向自己,這樣程式才能正確找到實作 協(xié)定方法函式的類別。
– (void)viewDidLoad { [super viewDidLoad]; myTextView.delegate = self; }
5. 關(guān)于鍵盤遮蔽的問題
如果您在實作上有遭遇到鍵盤遮蔽編輯區(qū)域的問題,可以參考使用 Animation
解決小鍵盤擋住 UITextField 的問題一文,透過 Core Graphic 的 Animation
功能,在鍵盤出現(xiàn)時同時移動編輯區(qū)域來解決遮蔽的問題。
6. 總結(jié)
這些鍵盤的問題,在平時的開發(fā)過程中都會遇到,有時候不怎么好處理。這篇文章寫的很詳細(xì),希望對大家的開發(fā)能有所幫助。
相關(guān)文章
iOS仿微博導(dǎo)航欄動畫(CoreGraphics)的實現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于iOS仿微博導(dǎo)航欄動畫(CoreGraphics)的實現(xiàn)方法,文章最后給出了完整的示例代碼,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07iOS利用UIScrollView實現(xiàn)無限滾動效果
這篇文章主要給大家介紹了iOS如何利用UIScrollView實現(xiàn)無限滾動的效果,首先需要說明的是,文本所講的是一種"笨辦法",但是好理解且容易實現(xiàn),在圖片不多的時候用它也無妨。感興趣的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。2016-12-12IOS開發(fā)之判斷兩個數(shù)組中數(shù)據(jù)是否相同實例詳解
這篇文章主要介紹了IOS開發(fā)之判斷兩個數(shù)組中數(shù)據(jù)是否相同實例詳解的相關(guān)資料,需要的朋友可以參考下2017-02-02iOS實現(xiàn)不規(guī)則Button點擊效果實例代碼
這篇文章主要給大家介紹了關(guān)于iOS實現(xiàn)不規(guī)則Button點擊的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04