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

    实现效果如下图所示:

    from:http://blog.csdn.net/wmqi10/article/details/8297316

  • 相关阅读:
    Python程序设计--第6章 面向对象编程
    Python程序设计--第5章 函数设计与使用
    Python程序设计--第4章 字符串与正则表达式
    Python程序设计--第3章 选择与循环
    Python程序设计--第2章 python序列
    Python程序设计--第1章 基础知识
    Python基本计算--除法
    ES6:对象新增方法
    ES6:字符串常用方法
    ES6:let和const用法
  • 原文地址:https://www.cnblogs.com/xuan52rock/p/5141535.html
Copyright © 2020-2023  润新知