重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
textView,textField 关闭键盘的方式网上有很多种,
创新互联建站-专业网站定制、快速模板网站建设、高性价比娄底网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式娄底网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖娄底地区。费用合理售后完善,10余年实体公司更值得信赖。最普遍的是使用键盘中回车键作为键盘关闭的信号,甚至有用户交互最差的监听键盘输入。再就是在键盘上添加关闭按钮,这个也不好,不够简约。还有在界面底部添加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
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。