UILabel 和UITextfield详解

一、UILabel

(1)初始化UILabel

[csharp]  view plain copy
  1. <span style="color:#000000;">UILabel *scoreLabel = [ [UILabel alloc ] initWithFrame:CGRectMake((self.bounds.size.width / 2), 0.0, 150.0, 43.0) ];  
  2.   
  3. scoreLabel.textAlignment =  UITextAlignmentCenter;  
  4.   
  5. scoreLabel.text = @"我是Andy--清风";  
  6.   
  7. scoreLabel.textColor = [UIColor whiteColor];  
  8.   
  9. scoreLabel.backgroundColor = [UIColor blackColor];  
  10.   
  11. scoreLabel.font = [UIFont fontWithName:@"Arial Rounded MT Bold" size:(36.0)];  
  12.   
  13. [self addSubview:scoreLabel];</span>  


 

(2)详细参数解释

[csharp]  view plain copy
  1. //设置显示文字       
  2.   
  3.    scoreLabel.text = @"我是Andy--清风";       
  4.   
  5.    
  6.   
  7. //设置字体:粗体,正常的是 SystemFontOfSize,调用系统的字体配置       
  8.   
  9.    scoreLabel.font = [UIFont boldSystemFontOfSize:20];       
  10.   
  11.    
  12.   
  13. //设置文字颜色,可以有多种颜色可以选择  
  14.   
  15.    scoreLabel.textColor = [UIColor orangeColor];       
  16.   
  17.    scoreLabel.textColor = [UIColor purpleColor];       
  18.   
  19.    
  20.   
  21. //设置文字对齐位置,居左,居中,居右       
  22.   
  23.    scoreLabel.textAlignment = UITextAlignmentRight;       
  24.   
  25.    scoreLabel.textAlignment = UITextAlignmentCenter;       
  26.   
  27. //设置字体大小是否适应label宽度       
  28.   
  29.    scoreLabel.adjustsFontSizeToFitWidth = YES;       
  30.   
  31.    
  32.   
  33. //设置label的行数,这个可以根据上节的UITextView自适应高度       
  34.   
  35.    scoreLabel.numberOfLines = 2;       
  36.   
  37.    
  38.   
  39.  //设置文本是否高亮和高亮时的颜色     
  40.   
  41.    scoreLabel.highlighted = YES;       
  42.   
  43.    scoreLabel.highlightedTextColor = [UIColor orangeColor];       
  44.   
  45.    
  46.   
  47. //设置阴影的颜色和阴影的偏移位置       
  48.   
  49.    scoreLabel.shadowColor = [UIColor redColor];       
  50.   
  51.    scoreLabel.shadowOffset = CGSizeMake(1.0,1.0);       
  52.   
  53.    
  54.   
  55. //设置是否能与用户进行交互       
  56.   
  57.    scoreLabel.userInteractionEnabled = YES;       
  58.   
  59.    
  60.   
  61.  //设置label中的文字是否可变,默认值是YES       
  62.   
  63.    scoreLabel.enabled = NO;       
  64.   
  65.    
  66.   
  67. //设置文字过长时的显示格式       
  68.   
  69.    scoreLabel.lineBreakMode = UILineBreakModeMiddleTruncation;//截去中间     





在定义里面允许有以下格式显示:  

[csharp]  view plain copy
  1. //  typedef enum {       
  2.   
  3.  //      UILineBreakModeWordWrap = 0,       
  4.   
  5.  //      UILineBreakModeCharacterWrap,       
  6.   
  7.  //      UILineBreakModeClip,//截去多余部分       
  8.   
  9.  //      UILineBreakModeHeadTruncation,//截去头部       
  10.   
  11.  //      UILineBreakModeTailTruncation,//截去尾部       
  12.   
  13.  //      UILineBreakModeMiddleTruncation,//截去中间       
  14.   
  15.  //  } UILineBreakMode;       




 

//如果adjustsFontSizeToFitWidth属性设置为YES,这个属性就来控制文本基线的行为    

[csharp]  view plain copy
  1. scoreLabel.baselineAdjustment = UIBaselineAdjustmentNone;     



在定义里面允许有以下格式显示:

[csharp]  view plain copy
  1. //  typedef enum {       
  2.   
  3. //      UIBaselineAdjustmentAlignBaselines,       
  4.   
  5. //      UIBaselineAdjustmentAlignCenters,       
  6.   
  7. //      UIBaselineAdjustmentNone,       
  8.   
  9. //  } UIBaselineAdjustment;       



//设置背景色为透明

[csharp]  view plain copy
  1. scoreLabel.backgroudColor=[UIColor clearColor];  



之外你还可以使用自定义的颜色:

[csharp]  view plain copy
  1. UIColor *color = [UIColor colorWithRed:1.0f green:50.0f blue:0.0f alpha:1.0f];  
  2. scoreLabel.textColor = [UIColor color];  
  3. //UIColor 里的 RGB 值是CGFloat类型的在0~1范围内,对应0~255的颜色值范围。  


 

二、UITextField

(1)初始化UITextField

[csharp]  view plain copy
  1. UITextField* text = [[UITextField alloc] initWithFrame:CGRectMake(10, 50, 300, 30)];  
  2.    
  3.     text.borderStyle = UITextBorderStyleRoundedRect;  
  4.    
  5.     text.autocorrectionType = UITextAutocorrectionTypeYes;  
  6.    
  7.     text.placeholder = @"您好,我是Andy—清风";  
  8.    
  9.     text.returnKeyType = UIReturnKeyDone;  
  10.    
  11.     text.clearButtonMode = UITextFieldViewModeWhileEditing;  
  12.    
  13.     [text setBackgroundColor:[UIColor whiteColor]];  
  14.    
  15.     text.delegate = self;  
  16.    
  17.     [self.view addSubview:text];  


(2)详细参数解释

borderStyle:文本框的边框风格

autocorrectionType:可以设置是否启动自动提醒更正功能。

placeholder:设置默认的文本显示

returnKeyType:设置键盘完成的按钮

backgroundColor:设置背景颜色

delegate:设置委托

(3)委托方法

 

[csharp]  view plain copy
  1. -(void)textFieldDidBeginEditing:(UITextField *)textField;  
  2.   
  3. //当开始点击textField会调用的方法  
  4.   
  5.    
  6.   
  7. -(void)textFieldDidEndEditing:(UITextField *)textField;  
  8.   
  9. //当textField编辑结束时调用的方法  
  10.   
  11. //按下Done按钮的调用方法,我们让键盘消失  
  12.   
  13. -(BOOL)textFieldShouldReturn:(UITextField *)textField{  
  14.   
  15.     [textField resignFirstResponder];  
  16.   
  17.     return YES;  
  18.   
  19. }  
  20. 来源:http://my.oschina.net/plumsoft/blog/42310


进入本文之前建议你认真读一读我的另一篇博文UIControl IOS控件编程 这样会起到事半功倍效果

 

为什么要看另一篇关于UIControl的文章呢?因为UITextField继承自UIControl类,很多UIControl的属性、方法、通知等完全适用于UITextField,而那些属于UIControl的东西我又不会在此赘述。(主要是减轻文章的长度,以最少的文字最通俗易懂讲明白一个知识点是我追求的目标。)

 

创建

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了,不过不要紧,我们调整调整就是了:

 

 iPhoneipad
竖屏(portrait)216264
横屏(landScape)140352

 

我们采取的方法就是在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;  
 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值