关于label的各种细节处理

来源:互联网 发布:黑客帝国 知乎 编辑:程序博客网 时间:2024/04/29 16:43

转自:http://blog.csdn.net/changesquare/article/details/11353413

iOS编程中UILabel是一个常用的控件,下面分享一下UILabel的相关属性设置的方法。

很多学习iOS6编程都是从storyboard开始,用到UILabel时是将控件拖到storyboard中生成实现,如果想要在-(void)viewDidLoad中用代码如[_label initWithFrame:CGRectMake(X,Y,WIDTH,HEIGHT)]方法改变拖拽到storyboardlabel的大小是行不通的,因为程序加载时先执行了-(void)viewDidLoad的代码,然后再加载storyboard,而storyboard会按照拖拽控件时设置的大小来生成label,即覆盖了在-(void)viewDidLoad中设置的大小,所以要动态设置label的大小应该用代码实现UILabel的创建

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(5050200400)];  
  2. [self.view addSubview:label];  
这样就用代码实现了label的创建,其中initWithFrame设置了label的位置还有大小,其中CGRectMake可以通过另外声明CGRect rect =CGRectMake(50,50,200,400)再将变量rect放在方法initWithFrame后实现CGRectMake的四个数值分别代表rect的位置坐标x值,坐标y值,宽度width,高度height。第二句[self.view addSubview:label]就是在当前的视图self.view中通过调用addSubview方法加入子视图,就像贴纸一样贴上去,会因为添加的顺序不同而发生后一个添加的子视图遮盖前一个子视图的现象,这个在后面讲为label添加背景图时还会提到。

或者用下面的代码来改变label的大小

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.frame = CGRectMake(974722319);  
设置label的标记(tag)

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.tag =101;   
设置label的文本内容

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.text =@"abcd"  或者  
  2. NSString *labelText = @"abcd";  
  3. label.text = labelText;  
把字符串的值赋给label
设置label的文字类型与大小

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.font = [UIFont systemFontOfSize:12];//采用系统默认文字设置大小  
  2. label.font = [UIFont fontWithName:@"Arial" size:30];//设置文字类型与大小  

设置label的文字颜色

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.textColor = [UIColor lightGrayColor];//其中textColor要用UIColor类型  

设置文本的对齐方式

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.textAlignment = NSTextAlignmentLeft;  

其中textAlignment有三种设置方式:NSTextAlignmentLeft为向左对齐,NSTextAlignmentCenter为居中对齐,NSTextAlignmentRight为向右对齐

如果有一些文章介绍时用的是UITextAlignmentCenter/UITextAlignmentLeft/UITextAlignmentRight,那是iOS6以前的用法,iOS6的最新用法已改

当文本内容很多,label无法全部显示时label会将文本内容以省略号的方式代替,下面说一下label文本省略方式的设置

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.lineBreakMode =NSLineBreakByCharWrapping;//其中lineBreakMode可选值为  
  2. linBreakMode enum{  
  3. NSLineBreakByWordWrapping = 0,//保留整个单词,以空格为边界  
  4.    NSLineBreakByCharWrapping,//保留整个字符  
  5.    NSLineBreakByClipping,//以边界为止  
  6.    NSLineBreakByTruncatingHead,//省略开头,以省略号代替  
  7.    NSLineBreakByTruncatingTail,//省略结尾,以省略号代替  
  8.    NSLineBreakByTruncatingMiddle//省略中间,以省略号代替  
  9.    }  
设置文本的行数

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.numberOfLines = 1;//行数设置为1,不设置时系统会默认行数为1  
当需要设置的行数为不限数量的时候可以用numberOfLines=0实现
当label大小使用sizeToFit方法,调整大小时会考虑到该属性中存储的值。例如,如果此属性设置为3,sizeToFit方法会调整label使它大到足以显示三行文本。
[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. [label sizeToFit];  
实现文本多行显示
[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. commentTextLabel.lineBreakMode = NSLineBreakByCharWrapping;  
  2. commentTextLabel.numberOfLines = 0;  
文本自动根据label大小自动调整字体尺寸

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.numberOfLines =1;  
  2. label.adjustsFontSizeToFitWidth =YES;  
adjustFontSizeToFitWidth方法可实现文本自动根据label大小自动调整字体尺寸,直到文本的大小达到了自己设置的label文本尺寸最大、最小值与字符串的最大最小值,要是用这个方法还有一个很大的限制就是只有在numberOfLines设置为1时才能用


如果行数是超过了1行,要实现自动调整字体大小功能,就没有可以自适应的系统方法可以使用,只有自己用代码实现,在设计时因为要考虑到手机屏幕的实际大小有限,如果字体太小会影响用户体验,所以要设置一个最小字号的判断,小于最小字号就要用到缩略显示,下面的代码中主要是用到
[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100180) lineBreakMode:NSLineBreakByCharWrapping];  

来得到字体在某一字号下的高度,判断与label高度是否一致,其中text是输入label的文本内容,sizWithFont设置字体,constrainedToSize设置约束文本的矩形大小参数,其中宽度要和label一致,高度设置要足够高,要比label高很多,否则会出现文本显示不全的问题,lineBreakMode的作用上文有讲过。如果算出的高度超出了label高度,就把字号以循环的方式减小直到高度符合就跳出循环。

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. float maxHeight =50;//设置最大高度  
  2.     float minFontSize =9;  
  3.     float height;  
  4.     int fontSize = 31;//设置最大字号  
  5.     NSString *text = @"输入文本内容";  
  6.     do {  
  7.         fontSize = fontSize - 1;  
  8.             UIFont *font =[UIFont fontWithName:@"Arial" size:fontSize];  
  9.             CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100180)/*宽度与label的宽度一样,高度应高于label高度*/ lineBreakMode:NSLineBreakByCharWrapping];  
  10.         height = size.height;  
  11.         NSLog(@"height=%f,fontSize=%d,text=%@",height,fontSize,text);  
  12.     } while (height > maxHeight&&fontSize>minFontSize);  
  13.   
  14.     UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(505010050)];  
  15.     label.text =text;  
  16.     if (fontSize ==9) {//判断字体是否小于最小字号,小于最小字号时就使用系统默认的缩略显示  
  17.         label.font = [UIFont fontWithName:@"Arial" size:15];  
  18.     }  
  19.     else{  
  20.     label.font = [UIFont fontWithName:@"Arial" size:fontSize];  
  21.     label.lineBreakMode = NSLineBreakByCharWrapping;//实现文字多行显示  
  22.     label.numberOfLines = 0;  
  23.     }  
  24.     [self.view addSubview:label];  
根据文本数量自动调整label高度
其实就是用上面的方法得到高度再生成label

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. NSString *text =[[NSString alloc]init];  
  2.   text = @"输入文本内容";  
  3.   CGSize size = CGSizeMake(280180);  
  4.   UIFont *fonts = [UIFont systemFontOfSize:14.0];  
  5.   CGSize msgSie = [text sizeWithFont:fonts constrainedToSize:size lineBreakMode: NSLineBreakByCharWrapping];  
  6.   UILabel *textLabel  = [[UILabel alloc] init];  
  7.   [textLabel setFont:[UIFont boldSystemFontOfSize:14]];  
  8.   textLabel.frame = CGRectMake(20,70280,msgSie.height);  
  9.   textLabel.text = text;  
  10.   textLabel.lineBreakMode = NSLineBreakByCharWrapping;//实现文字多行显示  
  11.   textLabel.numberOfLines = 0;  
  12.   [self.view addSubview:textLabel];  
设置label的边框粗细与颜色,设置前要在相应文件中加入#import<QuartzCore/QuartzCore.h>

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.layer.borderColor = [UIColor lightGrayColor].CGColor;//边框颜色,要为CGColor  
  2. label.layer.borderWidth = 1;//边框宽度  
设置label的背景颜色

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.backgroundColor =[UIColor yellowColor];  
设置label背景图
设置背景图有两种方法,下面先介绍第一种方法:
设置背景图可以把一张大小与label一样的图放在label的后面一层,然后把label的背景设置为透明,这样实现label有背景

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(5050200400)];  
  2. UIImageView *imageView =[[UIImageView alloc]init];  
  3. imageView.frame =CGRectMake(5050200400);  
  4. UIImage *image=[UIImage imageNamed:@"1.jpg"];  
  5. imageView.image =image;//imageView会根据自身大小改变添加的图片的大小所以不需要额外设置image  
  6. label.backgroundColor = [UIColor clearColor];  
  7. label.text =@"hello world";  
  8. label.font = [UIFont systemFontOfSize:30];  
  9. label.textColor = [UIColor yellowColor];  
  10. [self.view addSubview:imageView];//添加的顺序不能错,否则图片会覆盖label  
  11. [self.view addSubview:label];  
这个是一个有点不正统的方法,下面要介绍更加规范的第二种方法:用UIColor设置图片,然后把UIColor作为背景颜色,就可以实现label设置背景图

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. UIColor * color = [UIColor colorWithPatternImage:image];//image为需要添加的背景图  
  2.  UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(5050100200)];  
  3.  [label setBackgroundColor:color];  
  4.  [self.view addSubview:label];  
但这个方法有一个严重的缺陷,就是当背景图的尺寸与label大小不一致时,会出现背景图被部分截取或者平铺重复的情况,所以更完善的方法是要先修改好背景图的大小与label大小一致再设置背景颜色。可以用下面的函数设置image尺寸

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. -(UIImage *)scaleImage:(UIImage *)img ToSize:(CGSize)itemSize{  
  2.     UIImage *i;  
  3.     // 创建一个bitmap的context,并把它设置成为当前正在使用的context  
  4.     UIGraphicsBeginImageContext(itemSize);  
  5.     CGRect imageRect=CGRectMake(00, itemSize.width, itemSize.height);  
  6.     // 绘制改变大小的图片  
  7.     [img drawInRect:imageRect];  
  8.     // 从当前context中创建一个改变大小后的图片  
  9.     i=UIGraphicsGetImageFromCurrentImageContext();  
  10.     // 使当前的context出堆栈  
  11.     UIGraphicsEndImageContext();  
  12.     // 返回新的改变大小后的图片  
  13.     return i;  
  14. }  
然后在主函数中调用即可

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. CGSize size= CGSizeMake(100200);  
  2.     UIImage *image =[UIImage imageNamed:@"1.jpg"];  
  3.     UIImage *laterImage =[self scaleImage:image ToSize:size];  
  4.     UIColor * color = [UIColor colorWithPatternImage:laterImage];  
  5.    UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(5050100200)];  
  6.    [label setBackgroundColor:color];  
  7.    [self.view addSubview:label];  
设置高亮

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.highLighted =YES;  
设置文本阴影

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.shadowColor =[UIColor grayColor];  
设置阴影大小

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.shadowOffset = CGSizeMake(2.02.0);  
设置label圆角

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. label.layer.cornerRadius = 10;  
要是用这样的设置要先在头文件中加上#import<QuartzCore/QuartzCore.h>

0 0