码迷,mamicode.com
首页 > 移动开发 > 详细

iOS开发之点触textView编辑区关闭键盘

时间:2016-05-26 11:43:45      阅读:439      评论:0      收藏:0      [点我收藏+]

标签:ios开发   textview   关闭键盘   

textView,textField 关闭键盘的方式网上有很多种,

最普遍的是使用键盘中回车键作为键盘关闭的信号,甚至有用户交互最差的监听键盘输入。再就是在键盘上添加关闭按钮,这个也不好,不够简约。还有在界面底部添加subView,subView中添加按钮,属于在界面上添加关闭按钮类型的,键盘弹出之后通过动画上移整个subView至键盘顶部的,这是我以前采用的一种方式。不过界面东西太多,感觉界面越简约越好。

还有一种比较接近本文的是通过点击编辑区以外的view关闭键盘,但是用户还需要自己区分哪里是编辑区外,交互性也很差。如果textView需要覆盖整个view时,这种方法也就over了,因为整个界面除了textView就是键盘,view监听不到触摸事件,相应的函数就不会回调。

本文主要介绍如何在编辑textView时仅仅点击textView本身即可关闭键盘,这是目前比较主流的方式,可是网上几乎看不到相应的demon,特此献文一篇,如有不妥,请多指教,互相学习。

textView 字体、键盘类型设置什么的就不说了。

@implementation XXXXViewController{

UITapGestureRecognizer *tgr;//用于撤销键盘。

}

首先在viewWillAppear中注册键盘弹出关闭函数:

-(void)viewWillAppear:(BOOL)animated{

[[NSNotificationCentor defaultCenter] addObserver:self selector:@selector(keyboardDidShow:) name:UIKeyboardDidShowNotification object:nil];

[[NSNotificationCentor defaultCentor ] addObserver:self selector:@selector(keyboardDidHidden) name:UIKeyboardDidHideNotification object:nil];

[super viewWillAppear:YES];

}
接着在弹出键盘后调用的函数中添加点触事件,因为只有在键盘弹出之后需要监听触摸事件,键盘关闭状态时就不需要了,iOS默认触摸textView弹出键盘,如果此时还自定义一个监听事件,键盘恐怕就弹不出来了。

-(void)keyboardDidShow:(NSNotification *)notification{
UITapGestureRecognizer *tapGestureRecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(keyboardHide:)];

tapGestureRecognizer.cancelTouchesInView = NO;

[self.textView addGestureRecognizer:tapGestureRecognizer];

tgr = tapGestureRecognizer;//用于撤销触摸监听。

}

-(void)keyboardHide:(UITapGestureRecognizer *)tap{
[self.textView resignFirstResponder];

[self.textView removeGestureRecognizer:tgr];//撤销触摸监听,不然下次键盘弹不出。

}

OK,就这样,流程是这样。点触textView,弹出键盘(系统自带回调),添加点触监听,点触textView,关闭键盘,撤销点触监听,点触textView,弹出键盘(系统自带回调).....

转发标明出处,谢谢

http://control.blog.sina.com.cn/admin/article/article_add.php?is_new_editor=1


本文出自 “黯夜神之猫” 博客,请务必保留此出处http://ikingx.blog.51cto.com/10151780/1783301

iOS开发之点触textView编辑区关闭键盘

标签:ios开发   textview   关闭键盘   

原文地址:http://ikingx.blog.51cto.com/10151780/1783301

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!