IOS中输入框被软键盘遮挡的解决办法

做IOS开发时,难免会遇到输入框被键盘遮掩的问题。上网上搜索了很多相关的解决方案,看了很多,但是由衷的觉得太麻烦了。

    有的解决方案是将视图上的所有的东西都添加到一个滚动视图对象( UIScrollView )中,然后滚动视图实现输入框不被软键盘覆盖,个人觉得此方案好是好,但是太过麻烦。

    有的解决方案是通过一个通知 UIKeyboardDidShowNotification 去实现的,需要用到事件监听,而且需要自己定义并实现“将要开始编辑”与“结束编辑”这两个监听事件中的方法。本人也觉得很麻烦。

    参考了很多方法,都不是太理想。自己研究了一下,既然软键盘(Keyboard)出现与否是跟输入框(UITextField)紧密关联的。所以自己找到一个解决方案,没有上述两种方案那么麻烦,只需实现代理UITextFieldDelegate中的三个方法即可。

    实现方法

   1)将输入框的代理设置为self

       (在lb文件中将输入框的delegate设置为File’s Owner 。或者使用代码textField.delegate = self;

   2)将输入框所对应的ViewController.h设置实现了UITextFieldDelegate协议

         在ViewController.m文件中实现UITextFieldDelegate的三个方法即可:

[cpp]  view plain copy
  1. //开始编辑输入框的时候,软键盘出现,执行此事件  
  2. -(void)textFieldDidBeginEditing:(UITextField *)textField  
  3. {  
  4.     CGRect frame = textField.frame;  
  5.     int offset = frame.origin.y + 32 - (self.view.frame.size.height - 216.0);//键盘高度216  
  6.       
  7.     NSTimeInterval animationDuration = 0.30f;  
  8.     [UIView beginAnimations:@"ResizeForKeyboard" context:nil];  
  9.     [UIView setAnimationDuration:animationDuration];  
  10.       
  11.     //将视图的Y坐标向上移动offset个单位,以使下面腾出地方用于软键盘的显示  
  12.     if(offset > 0)  
  13.         self.view.frame = CGRectMake(0.0f, -offset, self.view.frame.size.width, self.view.frame.size.height);  
  14.       
  15.     [UIView commitAnimations];  
  16. }  
  17.   
  18. //当用户按下return键或者按回车键,keyboard消失  
  19. -(BOOL)textFieldShouldReturn:(UITextField *)textField  
  20. {  
  21.     [textField resignFirstResponder];  
  22.     return YES;  
  23. }  
  24.   
  25. //输入框编辑完成以后,将视图恢复到原始状态  
  26. -(void)textFieldDidEndEditing:(UITextField *)textField  
  27. {  
  28.     self.view.frame =CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height);  
  29. }  

方法很简单吧?请注意一定 不要忘记设置输入框的代理delegate

实现效果如下图所示:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容使用说明 YOLO高分设计资源源码,详情请查看资源内容使用说明 YOLO高分设计资源源码,详情请查看资源内容使用说明 YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明YOLO高分设计资源源码,详情请查看资源内容使用说明

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值