IOS TextFiled與TextView 鍵盤(pán)的收起以及處理鍵盤(pán)遮擋
IOS TextFiled與TextView 鍵盤(pán)的收起以及處理鍵盤(pán)遮擋
在iOS開(kāi)發(fā)中,UITextFiled和UITextView是很常見(jiàn)的兩個(gè)控件,當(dāng)我們?cè)O(shè)置好這兩個(gè)控件后,點(diǎn)擊文字輸入?yún)^(qū)域,系統(tǒng)會(huì)自動(dòng)彈出鍵盤(pán),但是如何收起鍵盤(pán)、點(diǎn)擊哪里收起鍵盤(pán),以及在iPhone4中鍵盤(pán)彈出后遮擋輸入框怎么辦呢?
這篇文章將帶領(lǐng)大家解決:
1》點(diǎn)擊其他空白區(qū)域收起鍵盤(pán)
2》點(diǎn)擊鍵盤(pán)右下角的鍵收起鍵盤(pán)
3》處理鍵盤(pán)遮擋問(wèn)題
一,點(diǎn)擊其他空白區(qū)域收起鍵盤(pán)
- (void)viewDidLoad {
[super viewDidLoad];
[self setUpForDismissKeyboard];
}
#pragma mark - 回收任何空白區(qū)域鍵盤(pán)事件
- (void)setUpForDismissKeyboard {
NSNotificationCenter *nc = [NSNotificationCenter defaultCenter];
UITapGestureRecognizer *singleTapGR =
[[UITapGestureRecognizer alloc] initWithTarget:self
action:@selector(tapAnywhereToDismissKeyboard:)];
NSOperationQueue *mainQuene =[NSOperationQueue mainQueue];
[nc addObserverForName:UIKeyboardWillShowNotification
object:nil
queue:mainQuene
usingBlock:^(NSNotification *note){
[self.view addGestureRecognizer:singleTapGR];
}];
[nc addObserverForName:UIKeyboardWillHideNotification
object:nil
queue:mainQuene
usingBlock:^(NSNotification *note){
[self.view removeGestureRecognizer:singleTapGR];
}];
}
- (void)tapAnywhereToDismissKeyboard:(UIGestureRecognizer *)gestureRecognizer {
//此method會(huì)將self.view里所有的subview的first responder都resign掉
[self.view endEditing:YES];
}
二,點(diǎn)擊鍵盤(pán)右下角的鍵收起鍵盤(pán)
#pragma mark - TextView 代理方法
-(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
{
if ([text isEqualToString:@"\n"]) {
[self.workLogTextView resignFirstResponder];
return NO;
}
return YES;
}
注意:需要遵守textView/textFiled的代理。改代碼是textView代理方法,若實(shí)際用到的是textFiled,只需調(diào)用textFiled的該類(lèi)方法即可。
三,處理鍵盤(pán)遮擋問(wèn)題
#pragma mark 鍵盤(pán)遮擋
- (BOOL)textViewShouldBeginEditing:(UITextView *)textView {
if (self.userInfo.isPhone4) {
CGFloat offset_y = 0.f;
if (textView.tag == CALL_CONTENT_TEXTFIRLD) {
offset_y = 100.f;
}
CGPoint point = self.BackScrollView.contentOffset;
point = CGPointMake(point.x, offset_y);
[UIView animateWithDuration:0.25 animations:^{
self.BackScrollView.contentOffset = point;
}];
}
return YES;
}
- (BOOL)textViewShouldEndEditing:(UITextView *)textView{
if (self.userInfo.isPhone4) {
CGFloat offset_y = 0.f;
if (textView.tag == CALL_CONTENT_TEXTFIRLD) {
offset_y = 100.f;
}
CGPoint point = self.BackScrollView.contentOffset;
point = CGPointMake(point.x, 0);
[UIView animateWithDuration:0.25 animations:^{
self.BackScrollView.contentOffset = point;
}];
}
return YES;
}
注意:需要遵守 UIScrollViewDelegate 和 textView/textFiled的代理。需要該頁(yè)面的父視圖是UIScrollView,才能保證彈出鍵盤(pán)時(shí)頁(yè)面向上移動(dòng),收起鍵盤(pán)時(shí)頁(yè)面向下移動(dòng)。代碼中的self.BackScrollView就是對(duì)應(yīng)的父視圖,使用時(shí)請(qǐng)?zhí)鎿Q掉。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
iOS將時(shí)間NSDate轉(zhuǎn)化為毫秒時(shí)間戳的方法示例
這篇文章主要給大家介紹了關(guān)于iOS將時(shí)間NSDate轉(zhuǎn)化為毫秒時(shí)間戳的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08
iOS 自定義狀態(tài)欄和導(dǎo)航欄詳細(xì)介紹
這篇文章主要介紹了iOS 自定義狀態(tài)欄和導(dǎo)航欄詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-11-11
iOS應(yīng)用中使用AsyncSocket庫(kù)處理Socket通信的用法講解
這篇文章主要介紹了iOS應(yīng)用中使用AsyncSocket庫(kù)處理Socket通信的用法講解,AsyncSocket同時(shí)支持TCP和UDP,文中展示了其建立斷開(kāi)連接及發(fā)送接收消息的操作,very好用,需要的朋友可以參考下2016-05-05
詳解iOS通過(guò)ASIHTTPRequest提交JSON數(shù)據(jù)
這篇文章主要介紹了詳解iOS通過(guò)ASIHTTPRequest提交JSON數(shù)據(jù),對(duì)代碼進(jìn)行了詳細(xì)的講解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-12-12
ios使用OC寫(xiě)算法之遞歸實(shí)現(xiàn)八皇后
本篇文章主要介紹了ios使用OC寫(xiě)算法之遞歸實(shí)現(xiàn)八皇后,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08

