zoukankan      html  css  js  c++  java
  • UI之UITextField--属性及用法

        

      1 // 初始化textfield,并设置textfield得位置及大小
      2     UITextField* field = [[UITextField alloc]initWithFrame:CGRectMake(100, 100, 100, 30)];
      3     // 设置textfield的位置及大小
      4     field.frame = CGRectMake(100, 100, 100, 30);
      5     // 设置标签
      6     field.tag = 1;
      7     // 设置透明度
      8     field.alpha = 0.5;
      9     // 是否允许输入;NO不允许输入,不弹出键盘
     10     field.enabled = YES;
     11     // 设置隐藏
     12     field.hidden = YES;
     13     // 是否开始输入的时候清空输入框内容;YES清空
     14     field.clearsOnBeginEditing = YES;
     15     
     16     // 自定义输入视图(默认是键盘)
     17     // field.inputView = myInputView;
     18     
     19     // 输入视图上方的辅助视图(默认nil)
     20     // field.inputAccessoryView = myAccessoryView;
     21     
     22     // 左视图显示模式,总是显示左视图
     23     field.leftViewMode = UITextFieldViewModeAlways;
     24     
     25     // 输入框右视图
     26     // field.rightView = rightView;
     27     
     28     // 设置高亮
     29     field.highlighted = YES;
     30     // 设置4个圆角半径
     31     field.layer.cornerRadius = 0.4;
     32     // 设置边框宽度
     33     field.layer.borderWidth = 0.5;
     34     // 设置边框颜色
     35     field.layer.borderColor = [UIColor blackColor].CGColor;
     36     // 设置外框类型
     37     [field setBorderStyle:UITextBorderStyleLine];
     38     // field.borderStyle = UITextBorderStyleLine;
     39     
     40     typedef  enum{
     41         UITextBorderStyleBezel,
     42         UITextBorderStyleLine,
     43         UITextBorderStyleRoundedRect,
     44         UITextBorderStyleNone,
     45     }UITextBorderStyle;
     46     
     47     // 设置输入框的背景颜色,此时设置为白色,如果使用了自定义的背景图片边框会被忽略掉
     48     field.backgroundColor = [UIColor whiteColor];
     49     // 设置背景,注意:背景只有是UITextBorderStyleNone的时候改属性有效
     50     field.background = [UIImage imageNamed:@"imageName"];
     51     // 设置背景
     52     field.disabledBackground = [UIImage imageNamed:@"imageName"];
     53     // 当输入框没有内容时,水印提示,内容为password
     54     field.placeholder = @"password";
     55     // 设置输入框内容的字体样式和大小
     56     field.font = [UIFont fontWithName:@"Arial" size:20];
     57     // 设置字体颜色
     58     field.textColor = [UIColor blueColor];
     59     // 输入框中是否有个x叉号,在什么时候显示,用于一次性删除输入框中的内容
     60     field.clearButtonMode = UITextFieldViewModeAlways;
     61     typedef  enum{
     62         UITextFieldViewModeNever, // 从不出现
     63         UITextFieldViewModeUnlessEditing, // 编辑时出现
     64         UITextFieldViewModeWhileEditing, // 除了编辑时都出现
     65         UITextFieldViewModeAlways, // 一直出现
     66     }UITextFieldViewMode;
     67     
     68     // 输入框一开始就有的文字
     69     field.text = @"一直显示文本";
     70     // 没输入一个字符就变成点,用于密码输入
     71     field.secureTextEntry = YES;
     72     // 是否纠错
     73     [field setAutocorrectionType:UITextAutocorrectionTypeDefault];
     74     typedef  enum{
     75         UITextAutocorrectionTypeDefault, // 默认
     76         UITextAutocorrectionTypeNo, // 不自动纠错
     77         UITextAutocorrectionTypeYes, // 自动纠错
     78     }UITextAutocorrectionType;
     79     // 再次编辑就清空
     80     field.clearsOnBeginEditing = YES;
     81     // 内容对齐方式
     82     field.textAlignment = NSTextAlignmentCenter; // 中心对齐
     83 //    NSTextAlignmentLeft; // 左对齐
     84 //    NSTextAlignmentRight; // 右对齐
     85     /* 内容的垂直对齐方式UITextField继承于UIControl,此类中有一个属性contentVerticalAlignment,
     86      field.contentVerticalAlignment = UIControlContentVerticalAlignmentCenter; */
     87     // 设置为YES时文本会自动缩小以适应文本窗口大小,默认时保持原来大小,而让长文本滚动
     88     field.adjustsFontSizeToFitWidth = YES;
     89     // 设置自动缩小显示的最小字体大小
     90     field.minimumFontSize = 20;
     91     // 设置键盘的样式
     92     field.keyboardType = UIKeyboardTypeNamePhonePad;
     93     typedef  enum{
     94         UIKeyboardTypeDefault, // 默认键盘,支持所有字符
     95         UIKeyboardTypeASCIICapable, // 支持ASCLL的默认键盘
     96         UIKeyboardTypeNumbersAndPunctuation, // 标准的电话键盘,支持+*#字符
     97         UIKeyboardTypeURL, // URL键盘,支持.com按钮,只支持URL字符
     98         UIKeyboardTypeNumberPad, // 数字键盘
     99         UIKeyboardTypeNamePhonePad, // 电话键盘
    100         UIKeyboardTypeEmailAddress, // 用于输入电子邮件地址的键盘
    101         UIKeyboardTypeDecimalPad, // 数字键盘,有小数和小数点
    102         UIKeyboardTypeTwitter, // 优化的键盘,方便输入@、#字符
    103         UIKeyboardWebSearch,
    104         UIKeyboardTypeAlphabet = UIKeyboardTypeASCIICapable,
    105     }UIKeyboardType;
    106     
    107     // 首字母是否大写
    108     field.autocapitalizationType = UITextAutocapitalizationTypeNone;
    109     typedef  enum{
    110         UITextAutocapitalizationTypeNone, // 不自动大写
    111         UITextAutocapitalizationTypeWords, // 单词首字母大写
    112         UITextAutocapitalizationTypeSentences, // 句子首字母大写
    113         UITextAutocapitalizationTypeAllCharacters, // 所有字母大写
    114     }UITextAutocapitalizationType;
    115     
    116     //return键变成什么键
    117     field.returnKeyType =UIReturnKeyDone;
    118     typedef enum {
    119         UIReturnKeyDefault, // 默认 灰色按钮,标有Return
    120         UIReturnKeyDone, // 标有Done的蓝色按钮
    121         UIReturnKeyGo, // 标有Go的蓝色按钮
    122         UIReturnKeyGoogle, // 标有Google的蓝色按钮,用语搜索
    123         UIReturnKeyJoin, // 标有Join的蓝色按钮
    124         UIReturnKeyNext, // 标有Next的蓝色按钮
    125         UIReturnKeyRoute, // 标有Route的蓝色按钮
    126         UIReturnKeySearch, // 标有Search的蓝色按钮
    127         UIReturnKeySend, // 标有Send的蓝色按钮
    128         UIReturnKeyYahoo, // 标有Yahoo的蓝色按钮
    129         UIReturnKeyEmergencyCall,  // 紧急呼叫按钮
    130     } UIReturnKeyType;
    131     
    132     //键盘外观
    133     field.keyboardAppearance=UIKeyboardAppearanceDefault;
    134     typedef enum {
    135         UIKeyboardAppearanceDefault, // 默认外观,浅灰色
    136         UIKeyboardAppearanceAlert, // 深灰 石墨色
    137         UIKeyboardAppearanceDark,
    138         UIKeyboardAppearanceLight,
    139     }UIKeyboardAppearance;
    140     // 最右侧加图片是一下代码
    141     UIImageView* image = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"imageName.png"]];
    142     field.rightView = image;
    143     field.rightViewMode = UITextFieldViewModeAlways;
    144     // 如果在最左侧加图片就换成
    145     field.leftView = image;
    146     field.leftViewMode = UITextFieldViewModeAlways;
    147 //    typedef  enum{
    148 //        UITextFieldViewModeNever, // 从不出现
    149 //        UITextFieldViewModeUnlessEditing, // 编辑时出现
    150 //        UITextFieldViewModeWhileEditing, // 除了编辑时都出现
    151 //        UITextFieldViewModeAlways, // 一直出现
    152 //    }UITextFieldViewMode;
    153     // 添加到视图上
    154     [self.view addSubview:field];

     如何用程序删除文本框中选中的文本

      [textView delete: nil];

        

      UITextFielde代理协议

      field.delegate = self; // 声明field的代理是我,我会去实现代理要做的事情

        1. 在你的控制器类中,加入UITextFieldDelegate这个协议

        如:@interface AddItemViewController : UIViewController <UITextFieldDelegate>

        2. 在使用了UITextFieldDelegate协议的控制器类的实现中,加入- (BOOL)textFieldShouldReturn:方法。

        - (BOOL)textFieldShouldReturn:(UITextField *)textField {

            

            [textField resignFirstResponder];

            return YES;

        }

        弹出键盘:

        [username becomeFirstResponder];

        取消键盘:

        [username resignFirstResponder];

        要实现的Delegate方法,关闭键盘

        - (BOOL)textFieldShouldReturn:(UITextField *)textField

        {

            [self.textField resignFirstResponder];

            return YES;

        }

        3. 可以在UITextField使用下面方法,按return键返回

        -(IBAction) textFieldDone:(id) sender

        {

            [textFieldName resignFirstResponder];

        }

        

        

    //    除了UITextField对象的风格选项,你还可以定制化UITextField对象,为他添加许多不同的重写方法,来改变文本字段的显示行为。这些方法都会返回一个CGRect结构,制定了文本字段每个部件的边界范围。以下方法都可以重写。

        

        – textRectForBounds:     //重写来重置文字区域

        – drawTextInRect:         //改变绘文字属性.重写时调用super可以按默认图形属性绘制,若自己完全重写绘制函数,就不用调用super了.

        – placeholderRectForBounds:  //重写来重置占位符区域

        – drawPlaceholderInRect:  //重写改变绘制占位符属性.重写时调用super可以按默认图形属性绘制,若自己完全重写绘制函数,就不用调用super了.

        – borderRectForBounds:  //重写来重置边缘区域

        – editingRectForBounds:  //重写来重置编辑区域

        – clearButtonRectForBounds:  //重写来重置clearButton位置,改变size可能导致button的图片失真

        – leftViewRectForBounds:

        – rightViewRectForBounds:

        

        代替输入

        inputView //代替标准的系统键盘

        inputAccessoryView //编辑时显示在系统键盘或用户自定义的inputView上面的视图

        

        

        委托方法

        - (BOOL)textFieldShouldBeginEditing:(UITextField *)textField{

              

            //返回一个BOOL值,指定是否循序文本字段开始编辑

              

            return YES;

        }

        

        - (void)textFieldDidBeginEditing:(UITextField *)textField{

            //开始编辑时触发,文本字段将成为first responder

        }

        

        - (BOOL)textFieldShouldEndEditing:(UITextField *)textField{

            //返回BOOL值,指定是否允许文本字段结束编辑,当编辑结束,文本字段会让出first responder

              //要想在用户结束编辑时阻止文本字段消失,可以返回NO

              //这对一些文本字段必须始终保持活跃状态的程序很有用,比如即时消息

              

            return NO;

        }

        - (void)textFieldDidEndEditing:(UITextField *)textField;{

            

        }// 上面返回YES后执行;上面返回NO时有可能强制执行(e.g. view removed from window)

        

        - (BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{

            //当用户使用自动更正功能,把输入的文字修改为推荐的文字时,就会调用这个方法。

            //这对于想要加入撤销选项的应用程序特别有用

            //可以跟踪字段内所做的最后一次修改,也可以对所有编辑做日志记录,用作审计用途。

            //要防止文字被改变可以返回NO

            //这个方法的参数中有一个NSRange对象,指明了被改变文字的位置,建议修改的文本也在其中

            

                return YES;

        }

        

        - (BOOL)textFieldShouldClear:(UITextField *)textField{

            

            //返回一个BOOL值指明是否允许根据用户请求清除内容

            //可以设置在特定条件下才允许清除内容

            

                return YES;

        }

        

        -(BOOL)textFieldShouldReturn:(UITextField *)textField{

            

            //返回一个BOOL值,指明是否允许在按下回车键时结束编辑

            //如果允许要调用resignFirstResponder 方法,这回导致结束编辑,而键盘会被收起[textField resignFirstResponder];

            //查一下resign这个单词的意思就明白这个方法了

                return YES;

        }

        

        

    //    

    //    通知

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

        

        UITextFieldTextDidBeginEditingNotification

        UITextFieldTextDidChangeNotification

        UITextFieldTextDidEndEditingNotification

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

        

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

        

        UIKeyboardWillShowNotification  //键盘显示之前发送

        UIKeyboardDidShowNotification   //键盘显示之后发送

        UIKeyboardWillHideNotification  //键盘隐藏之前发送

        UIKeyboardDidHideNotification   //键盘隐藏之后发送

        NIB中:

        1、Text :设置文本框的默认文本。

        2、Placeholder : 可以在文本框中显示灰色的字,用于提示用户应该在这个文本框输入什么内容。当这个文本框中输入了数据时,用于提示的灰色的字将会自动消失。

        3、Background :

        4、Disabled : 若选中此项,用户将不能更改文本框内容。

        5、接下来是三个按钮,用来设置对齐方式。

        6、Border Style : 选择边界风格。

        7、Clear Button : 这是一个下拉菜单,你可以选择清除按钮什么时候出现,所谓清除按钮就是出一个现在文本框右边的小 X ,你可以有以下选择:

        7.1 Never appears : 从不出现

        7.2 Appears while editing : 编辑时出现

            7.3 Appears unless editing :

            7.4 Is always visible : 总是可见

            8、Clear when editing begins : 若选中此项,则当开始编辑这个文本框时,文本框中之前的内容会被清除掉。比如,你现在这个文本框 A 中输入了 "What" ,之后去编辑文本框 B,若再回来编辑文本框 A ,则其中的 "What" 会被立即清除。

            9、Text Color : 设置文本框中文本的颜色。

            10、Font : 设置文本的字体与字号。

            11、Min Font Size : 设置文本框可以显示的最小字体(不过我感觉没什么用)

            12、Adjust To Fit : 指定当文本框尺寸减小时,文本框中的文本是否也要缩小。选择它,可以使得全部文本都可见,即使文本很长。但是这个选项要跟 Min Font Size 配合使用,文本再缩小,也不会小于设定的 Min Font Size 。

            接下来的部分用于设置键盘如何显示。

            13、Captitalization : 设置大写。下拉菜单中有四个选项:

            13.1 None : 不设置大写

            13.2 Words : 每个单词首字母大写,这里的单词指的是以空格分开的字符串

            13.3 Sentances : 每个句子的第一个字母大写,这里的句子是以句号加空格分开的字符串

            13.4 All Characters : 所以字母大写

            14、Correction : 检查拼写,默认是 YES 。

            15、Keyboard : 选择键盘类型,比如全数字、字母和数字等。

            16、Appearance:

            17、Return Key : 选择返回键,可以选择 Search 、 Return 、 Done 等。

            18、Auto-enable Return Key : 如选择此项,则只有至少在文本框输入一个字符后键盘的返回键才有效。

            19、Secure : 当你的文本框用作密码输入框时,可以选择这个选项,此时,字符显示为星号。

            

            

            1.Alignment Horizontal 水平对齐方式

            2.Alignment Vertical 垂直对齐方式

            3.用于返回一个BOOL值 输入框是否 Selected(选中) Enabled(可用) Highlighted(高亮)

            

            实例 : UITextField限制字符 (只为数字)

    #define ALPHA @"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz "

    #define NUMBERS @"0123456789n"

    #define ALPHANUM @"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789 "

    #define NUMBERSPERIOD @"0123456789."

    - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string

        {

            NSCharacterSet *cs;

            cs = [[NSCharacterSet characterSetWithCharactersInString:NUMBERSPERIOD ] invertedSet]; //invertedSet 方法是去反字符,把所有的除了数字的字符都找出来

            

            NSString *filtered = [[string componentsSeparatedByCharactersInSet:cs] componentsJoinedByString:@""];  //componentsSeparatedByCharactersInSet 方法是把输入框输入的字符string 根据cs中字符一个一个去除cs字符并分割成单字符并转化为 NSArray, 然后componentsJoinedByString 是把NSArray 的字符通过 ""无间隔连接成一个NSString字符 赋给filtered.就是只剩数字了.

            BOOL basicTest = [string isEqualToString:filtered];

            if(!basicTest)

                

            {

                UIAlertView* alert = [[UIAlertView alloc] initWithTitle:@"提示"

                                                                message:@"请输入数字"

                                                               delegate:nil

                                                      cancelButtonTitle:@"确定"

                                                      otherButtonTitles:nil];

                

                [alert show];

                [alert release];

                return NO;

            }

            

            // Add any predicate testing here

            return basicTest;

        }

                                  

    #define NUMBERS @”0123456789n” (这个代表可以输入数字和换行,请注意这个n,如果不写这个,Done按键将不会触发,如果用在SearchBar中,将会不触发Search事件,因为你自己限制不让输入n,好惨,我在项目中才发现的。) 所以,如果你要限制输入英文和数字的话,就可以把这个定义为: #define kAlphaNum @”ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789″。 当然,你还可以在以上方法return之前,做一提示的,比如提示用户只能输入数字之类的。如果你觉得有需要的话。

        UItextField UITextView 有关键盘的设置

        autocapitalizationType            设置键盘自动大小写的属性     UITextAutocapitalizationTypeNone

        autocorrectionType  property  设置是否有自动修改提示   UITextAutocorrectionTypeNo

        enablesReturnKeyAutomatically   Boolean值-设置在用户没有输入是returnKey禁用,默认值NO

        keyboardAppearance  设置键盘显示方式  除了默认模式  还有一个UIKeyboardAppearanceAlert模式

        keyboardType               设置键盘类型   UIKeyboardTypePhonePad 等

        returnKeyType              设置renturnKey按键上的提示文字     UIReturnKeyGo   UIReturnKeyNext

        secureTextEntry           BOOL值  -- 设置是否是密码保护模式输入

                                  

                                  

        用户名输入框:

        m_TF_username = [[UITextField alloc] initWithFrame:my_frame];

        m_TF_username.borderStyle = UITextBorderStyleNone;

        m_TF_username.clearButtonMode = UITextFieldViewModeWhileEditing;

        m_TF_username.delegate = self;

        m_TF_username.returnKeyType = UIReturnKeyNext;

        m_TF_username.autocapitalizationType = UITextAutocapitalizationTypeNone;

        [m_TF_username becomeFirstResponder];

                                  

        密码输入框:

        m_TF_password = [[UITextField alloc] initWithFrame:my_frame];

        m_TF_password.borderStyle = UITextBorderStyleNone;

        m_TF_password.clearButtonMode = UITextFieldViewModeWhileEditing;

        m_TF_password.delegate = self;

        m_TF_password.returnKeyType = UIReturnKeyGo;

        m_TF_password.secureTextEntry =YES;

     

  • 相关阅读:
    Redis笔记 —— string 篇
    解决跨域请求无法携带Cookie的问题
    Mysql事务学习笔记
    Redis笔记 —— hash 篇
    mysql视图的简单学习
    axios无法被识别为ajax请求的解决方案
    常见header信息详解
    int 15h
    操作系统有进程了
    是时候走我自己的路线了,真正的做我自己的Jinux
  • 原文地址:https://www.cnblogs.com/WillingToAsk1946zzh/p/4470132.html
Copyright © 2011-2022 走看看