• UITextField 文本字段控件 IOS (解决键盘遮住View及密文設定的问题)(实例)(转)


    创建

    C代码  收藏代码
    1. UITextField* myTextField = [[UITextField alloc]initWithFrame:CGRectMake(50, 100, 200, 50)];   

     

    纯代码创建View请参看我的另一片博文:有关View的几个基础知识点-IOS开发 (实例)

     

    设置委托

    C代码  收藏代码
    1. myTextField.delegate = self;//委托类需要遵守UITextFieldDelegate协议    

     

    设置属性

    UIControl属性对UITextField完全可以用,下面的都是UITextFiels扩展的属性:

    C代码  收藏代码
    1. myTextField.textAlignment = UITextAlignmentLeft;//默认就是左对齐,这个是UITextField扩展属性    
    2. myTextField.borderStyle = UITextBorderStyleBezel;//默认是没有边框,如果使用了自定义的背景图片边框会被忽略掉    
    3. myTextField.placeholder = @"请在此输入账号";//为空白文本字段绘制一个灰色字符串作为占位符    
    4. myTextField.clearsOnBeginEditing = YES;//设置为YES当用点触文本字段时,字段内容会被清除    
    5. myTextField.adjustsFontSizeToFitWidth = YES;//设置为YES时文本会自动缩小以适应文本窗口大小。默认是保持原来大小,而让长文本滚动    
    6. //myTextField.background = [UIImage imageNamed:@"registBtn"];//可以接受UIImage对象,此项设置则边框失效。    
    7. myTextField.clearButtonMode = UITextFieldViewModeUnlessEditing;//右边显示的'X'清楚按钮    
    8. //myTextField.LeftView =    
    9. //myTextField.leftViewMode =     
    10. //myTextField.RightView =    
    11. //myTextField.rightViewMode =    

     

    这些属性令你可以将UIView的派生类附着于为本字段的左方或右方。人们通常会将UIButton对象,比如放大镜或者书签按钮附着与文本字段上。每个附着视图都会有一个相应的模式,设置clearButtonmode属性的那些值,同样可以设置这个模式。

     

    显示

    C代码  收藏代码
    1. [self.view addSubview:myTextField];    

     

    重写绘制行为

    除了UITextField对象的风格选项,你还可以定制化UITextField对象,为他添加许多不同的重写方法,来改变文本字段的显示行为。这些方法都会返回一个CGRect结构,制定了文本字段每个部件的边界范围。如果你创见了一个自定义的UITextField类,你可以重写这些方法,这样就可以改变一个或多个边界。一定不要直接调用 fan广发;它们都是被iPhone运行库调用的回调函数下面举个例子:

    C代码  收藏代码
    1. - (CGRect)clearButtonForBounds:(CGRect)bounds{    
    2.     return CGRectMake(bounds.origin.x +bounds.size.width-50,     
    3.                       bounds.origin.y+bounds.size.height-20, 16, 16);    
    4. }    

     

    下列方法在创建一个UITextField的子类时可以重写:

    borderRectForBounds

    指定矩形边界

    textRectForBounds

     指定显示文本的边界

    placeholderRectForBounds

    指定站位文本的边界

    editingRectForBounds

    指定编辑中文本的边界

    clearButtonRectForBounds

    指定显示清除按钮的边界

    leftViewRectForBounds

    指定显示左附着视图的边界

    rightViewRectForBounds

    指定显示右附着视图的边界

     

    委托方法

    C代码  收藏代码
    1. - (BOOL)textFieldShouldBeginEditing:(UITextField *)textField{    
    2.     //返回一个BOOL值,指定是否循序文本字段开始编辑    
    3.     return YES;    
    4. }    
    C代码  收藏代码
    1. - (void)textFieldDidBeginEditing:(UITextField *)textField{  
    2.     //开始编辑时触发,文本字段将成为first responder  
    3. }  
    C代码  收藏代码
    1. - (BOOL)textFieldShouldEndEditing:(UITextField *)textField{  
    2.     //返回BOOL值,指定是否允许文本字段结束编辑,当编辑结束,文本字段会让出first responder  
    3.     //要想在用户结束编辑时阻止文本字段消失,可以返回NO  
    4.     //这对一些文本字段必须始终保持活跃状态的程序很有用,比如即时消息  
    5.     return NO;  
    6. }  
    C代码  收藏代码
    1. - (BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{  
    2.     //当用户使用自动更正功能,把输入的文字修改为推荐的文字时,就会调用这个方法。  
    3.     //这对于想要加入撤销选项的应用程序特别有用  
    4.     //可以跟踪字段内所做的最后一次修改,也可以对所有编辑做日志记录,用作审计用途。     
    5.     //要防止文字被改变可以返回NO  
    6.     //这个方法的参数中有一个NSRange对象,指明了被改变文字的位置,建议修改的文本也在其中  
    7.     return YES;  
    8. }  
    C代码  收藏代码
    1. - (BOOL)textFieldShouldClear:(UITextField *)textField{  
    2.     //返回一个BOOL值指明是否允许根据用户请求清除内容  
    3.     //可以设置在特定条件下才允许清除内容  
    4.     return YES;  
    5. }  
    C代码  收藏代码
    1. -(BOOL)textFieldShouldReturn:(UITextField *)textField{  
    2.     //返回一个BOOL值,指明是否允许在按下回车键时结束编辑  
    3.     //如果允许要调用resignFirstResponder 方法,这回导致结束编辑,而键盘会被收起  
    4.     [textField resignFirstResponder];//查一下resign这个单词的意思就明白这个方法了  
    5.     return YES;  
    6. }  

         

     通知

    UITextField派生自UIControl,所以UIControl类中的通知系统在文本字段中也可以使用。除了UIControl类的标准事件,你还可以使用下列UITextField类特有的事件

    UITextFieldTextDidBeginEditingNotification

    UITextFieldTextDidChangeNotification

    UITextFieldTextDidEndEditingNotification

    当文本字段退出编辑模式时触发。通知的object属性存储了最终文本。

    因为文本字段要使用键盘输入文字,所以下面这些事件发生时,也会发送动作通知

    UIKeyboardWillShowNotification

    键盘显示之前发送

    UIKeyboardDidShowNotification

    键盘显示之后发送

    UIKeyboardWillHideNotification

    键盘隐藏之前发送

    UIKeyboardDidHideNotification

    键盘隐藏之后发送

     

    打开键盘卷动文本字段

    默认情况下打开键盘会遮住下面的view,带来一点点困扰,不过这不是什么大问题,我们使用点小小的手段就可以解决。

     

    首先我们要知道键盘的高度是固定不变的,不过在IOS 5.0 以后键盘的高度貌似不是216了,不过不要紧,我们调整调整就是了:

     

      iPhone ipad
    竖屏(portrait) 216 264
    横屏(landScape) 140 352

     

    我们采取的方法就是在textField(有可能是其他控件)接收到弹出键盘事件时把self.view整体上移216px了(我们就以iPhone竖屏为例了)。

    有关View的frame,origin,size之类的知识点不懂的请参看我的另一篇博文: 有关View的几个基础知识点-IOS开发 (实例)

     

    首先我们要设置textField的代理,我们就设为当前控制器了。

     

    C代码  收藏代码
    1. textField,delegate=self;  

      

    然后我们在当前控制器实现下面两个委托方法:

    C代码  收藏代码
    1. - (void)textFieldDidBeginEditing:(UITextField *)textField  
    2. //当点触textField内部,开始编辑都会调用这个方法。textField将成为first responder   
    3.        NSTimeInterval animationDuration = 0.30f;      
    4.       CGRect frame = self.view.frame;  
    5.       frame.origin.y -=216;  
    6.       frame.size.height +=216;  
    7.       self.view.frame = frame;  
    8.        [UIView beginAnimations:@"ResizeView" context:nil];  
    9.        [UIView setAnimationDuration:animationDuration];  
    10.        self.view.frame = frame;                  
    11.        [UIView commitAnimations];                  
    12. }  
    C代码  收藏代码
    1. - (BOOL)textFieldShouldReturn:(UITextField *)textField   
    2. {//当用户按下ruturn,把焦点从textField移开那么键盘就会消失了  
    3.         NSTimeInterval animationDuration = 0.30f;  
    4.         CGRect frame = self.view.frame;      
    5.         frame.origin.y +=216;        
    6.         frame.size. height -=216;     
    7.         self.view.frame = frame;  
    8.     //self.view移回原位置    
    9.     [UIView beginAnimations:@"ResizeView" context:nil];  
    10.     [UIView setAnimationDuration:animationDuration];  
    11.         self.view.frame = frame;                  
    12.         [UIView commitAnimations];  
    13.         [textField resignFirstResponder];     
    14. }         

     

    实例:

    C代码  收藏代码
    1. - (void)viewDidLoad  
    2. {  
    3.     [super viewDidLoad];  
    4.     // Do any additional setup after loading the view, typically from a nib.  
    5.     //创建  
    6.     UITextField *myTextField = [[UITextField alloc]initWithFrame:CGRectMake(50, 300, 200, 60)];  
    7.       
    8.     myTextField.delegate = self;//设置委托  
    9.       
    10.     //设置属性  
    11.     myTextField.contentVerticalAlignment = UIControlContentVerticalAlignmentCenter;// 垂直对齐方式,可以注视掉看看默认是什么效果  
    12.     myTextField.textAlignment = UITextAlignmentLeft;//默认就是左对齐,这个是UITextField扩展属性  
    13.     myTextField.borderStyle = UITextBorderStyleBezel;//默认是没有边框,如果使用了自定义的背景图片边框会被忽略掉  
    14.     myTextField.placeholder = @"请在此输入账号";//为空白文本字段绘制一个灰色字符串作为占位符  
    15.     myTextField.clearsOnBeginEditing = YES;//设置为YES当用点触文本字段时,字段内容会被清除  
    16.     myTextField.adjustsFontSizeToFitWidth = YES;//设置为YES时文本会自动缩小以适应文本窗口大小。默认是保持原来大小,而让长文本滚动  
    17.     //myTextField.background = [UIImage imageNamed:@"registBtn"];//可以接受UIImage对象,此项设置则边框失效。  
    18.     myTextField.clearButtonMode = UITextFieldViewModeUnlessEditing;//右边显示的'X'清楚按钮  
    19.       
    20.     [self.view addSubview:myTextField];//显示  
    21.     myTextField = nil;  
    22.   
    23. }  
    24.   
    25. //委托方法  
    26. - (BOOL)textFieldShouldBeginEditing:(UITextField *)textField{  
    27.     //返回一个BOOL值,指定是否循序文本字段开始编辑  
    28.     return YES;  
    29. }  
    30. - (void)textFieldDidBeginEditing:(UITextField *)textField{  
    31.     //开始编辑时触发,文本字段将成为first responder  
    32.       
    33.     //键盘遮住了文本字段,视图整体上移  
    34.     CGRect frame = self.view.frame;  
    35.     frame.origin.y -=120;  
    36.     frame.size.height +=120;  
    37.     self.view.frame = frame;  
    38. }  
    39. - (BOOL)textFieldShouldEndEditing:(UITextField *)textField{  
    40.     //返回BOOL值,指定是否允许文本字段结束编辑,当编辑结束,文本字段会让出first responder  
    41.     //要想在用户结束编辑时阻止文本字段消失,可以返回NO  
    42.     //这对一些文本字段必须始终保持活跃状态的程序很有用,比如即时消息  
    43.     NSLog(@"here is code: %@",textField.text);  
    44.     return YES;  
    45. }  
    46. - (BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{  
    47.     //当用户使用自动更正功能,把输入的文字修改为推荐的文字时,就会调用这个方法。  
    48.     //这对于想要加入撤销选项的应用程序特别有用  
    49.     //可以跟踪字段内所做的最后一次修改,也可以对所有编辑做日志记录,用作审计用途。     
    50.     //要防止文字被改变可以返回NO  
    51.     //这个方法的参数中有一个NSRange对象,指明了被改变文字的位置,建议修改的文本也在其中  
    52.       
    53.     return YES;  
    54. }  
    55. - (BOOL)textFieldShouldClear:(UITextField *)textField{  
    56.     //返回一个BOOL值指明是否允许根据用户请求清除内容  
    57.     //可以设置在特定条件下才允许清除内容  
    58.     return YES;  
    59. }  
    60. -(BOOL)textFieldShouldReturn:(UITextField *)textField{  
    61.     //之前视图上移了  现在移回来  
    62.     CGRect frame = self.view.frame;  
    63.     frame.origin.y +=120;  
    64.     frame.size.height -=120;  
    65.     self.view.frame = frame;  
    66.     NSLog(@"textfield:%@", textField);  
    67.     //返回一个BOOL值,指明是否允许在按下回车键时结束编辑  
    68.     //如果允许要调用resignFirstResponder 方法,这回导致结束编辑,而键盘会被收起  
    69.     [textField resignFirstResponder];//查一下resign这个单词的意思就明白这个方法了  
    70.     return YES;  
    71. }  

     

     

    来源: http://blog.csdn.net/iukey/article/details/7301150

     

     

    UITextField 的密文设定方式

     

     

     

    通常在输入密码或是制作一些特殊效果时,UITextField 会使用密文来保护所输入的文字,下列我们将使用两种不同的方式来示范如何设定 UITextField 的密文保护。

     

     一个最简单又直接的方式,当介面上已经拉出一个 UITextField 时,我们可以透过 Interface Builder 直接设定,点选所要的 UITextField 点选属性标籤页 Attributes inspector,并找到 Secure 的 CheckBox 打勾即可,如下图。

     

     

     另一种方式,就是从程式里面直接做设定,常用在动态产生 UITextField 时,其程式码如下。

     

    C代码  收藏代码
    1. passwordTextField.secureTextEntry = YES;  
  • 相关阅读:
    RedGlove 权限管理系统(1)权限概述
    SPQuery查询语法简要说明
    DataGridView使用技巧大全
    实战asp.net MVC+ADO.NET EntityFramework
    RedGlove 权限管理系统(2)功能模块设计
    C# 如果何从线程中操作控件
    PageHelper 类 和 ValidateHelper 类
    字符串帮助类
    XMLHelper 类
    Android中截取当前屏幕的功能
  • 原文地址:https://www.cnblogs.com/lzjsky/p/2966292.html
Copyright © 2020-2023  润新知