UI之UILabel--属性及用法
1 // 初始化Label,并设置label的位置及大小
2 UILabel* label = [[UILabel alloc]initWithFrame:CGRectMake(50, 100, 100, 40)];
3
4 // 设置label位置及大小
5 label.frame = CGRectMake(50, 100, 100, 40);
// enabled属性如果设置为No,则文字颜色会变暗,表明其是不可用的,默认值为YES
label.enabled = YES;
6
7 // 设置背景颜色
8 label.backgroundColor = [UIColor yellowColor];
9
10 // 清除背景颜色
11 label.backgroundColor = [UIColor clearColor];
12
13 // 设置高亮
14 label.highlighted = YES;
15
16 // 设置隐藏
17 label.hidden = NO;
18
19
20 // 设置文本阴影
21 label.shadowColor = [UIColor grayColor];
22
23 // 设置阴影大小
24 label.shadowOffset = CGSizeMake(2.0, 2.0);
25
26 // 设置圆角
27 label.layer.cornerRadius = 10;
28
29 // 设置label的边框粗细与颜色,设置前要在相应文件中加入#import<QuartzCore/QuartzCore.h>
30 // 设置边框宽度
31 label.layer.borderWidth = 1;
32
33 // 设置边框颜色
34 label.layer.borderColor = [UIColor redColor].CGColor;
35
36 // 设置标签
37 label.tag = 1;
38
39 // 设置文本内容
40 label.text = @"abcd";
41
42 // 把字符串的值赋值给label
43 NSString* textLabel = @"abce";
44 label.text = textLabel;
45
46 // 设置文本类型及文本大小
47 label.font = [UIFont fontWithName:@"Arial" size:30];
48 // [label setFont:[UIFont fontWithName:@"Arial" size:30]];
49
50 // 采用系统默认文字类型设置大小
51 label.font = [UIFont systemFontOfSize:12];
52 // [label setFont:[UIFont systemFontOfSize:12]];
53
54 // 设置文本颜色
55 label.textColor = [UIColor redColor];
56 // [label setTextColor:[UIColor lightGrayColor]];
57
58 // 设置文本对齐方式
59 label.textAlignment = NSTextAlignmentLeft;
60 // [label setTextAlignment:NSTextAlignmentLeft];
61
62 /* 其中textAlignment有三种设置方式:NSTextAlignmentLeft为向左对齐,NSTextAlignmentCenter为居中对齐,NSTextAlignmentRight为向右对齐
63 如果有一些文章介绍时用的是UITextAlignmentCenter/UITextAlignmentLeft/UITextAlignmentRight,那是iOS6以前的用法,iOS6的最新用法已改 */
64
65 /* 当文本内容很多,label无法全部显示时label会将文本内容以省略号的方式代替,
66 下面说一下label文本省略方式的设置 */
67 // 其中lineBreakMode为可选值
68 [label setLineBreakMode:NSLineBreakByCharWrapping];
69 // label.lineBreakMode = NSLineBreakByCharWrapping;
70 // linBreakMode enum{
71 // NSLineBreakByWordWrapping = 0,//保留整个单词,以空格为边界
72 // NSLineBreakByCharWrapping,//保留整个字符
73 // NSLineBreakByClipping, //以边界为止
74 // NSLineBreakByTruncatingHead,//省略开头,以省略号代替
75 // NSLineBreakByTruncatingTail,//省略结尾,以省略号代替
76 // NSLineBreakByTruncatingMiddle//省略中间,以省略号代替
77 // }
78
79 // 设置文本行数
80 label.numberOfLines = 1; // 不设置时系统会默认行数为1;
81
82 /* 当需要设置的行数为不限数量时,可以用numberOfLines = 0;实现,会自动换行
83 当label大小使用sizeToFit方法时,调整大小时会考虑到该属性中存储的值。
84 例如:如果此属性设置为3,sizeTOFit方法会调整label使它大到足以显示三行文本 */
85 [label sizeToFit];
86
87 // 实现文本多行显示
88 label.lineBreakMode = NSLineBreakByCharWrapping;
89 label.numberOfLines = 0;
90
91 // 文本自动根据label大小自动调整字体尺寸
92 label.numberOfLines = 1;
93 label.adjustsFontSizeToFitWidth = YES;
94 /* adjustFontSizeToFitWidth方法可实现文本自动根据label大小自动调整字体尺寸,直到文本的大小达到了自己设置的label文本尺寸最大、最小值与字符串的最大最小值,要是用这个方法还有一个很大的限制就是只有在numberOfLines设置为1时才能用 */
95
96 /* 如果行数是超过了1行,要实现自动调整字体大小功能,就没有可以自适应的系统方法可以使用,只有自己用代码实现,在设计时因为要考虑到手机屏幕的实际大小有限,如果字体太小会影响用户体验,所以要设置一个最小字号的判断,小于最小字号就要用到缩略显示,下面的代码中主要是用到:
97
98 CGSize size = [label sizeWithFont:font constrainedToSize:CGSizeMake(100, 180) lineBreakMode:NSLineBreakByCharWrapping];
99
100 来得到字体在某一字号下的高度,判断与label高度是否一致,其中text是输入label的文本内容,sizWithFont设置字体,constrainedToSize设置约束文本的矩形大小参数,其中宽度要和label一致,高度设置要足够高,要比label高很多,否则会出现文本显示不全的问题,lineBreakMode的作用上文有讲过。如果算出的高度超出了label高度,就把字号以循环的方式减小直到高度符合就跳出循环。
101
102 float maxHeight =50;//设置最大高度
103 float minFontSize =9;
104 float height;
105 int fontSize = 31;//设置最大字号
106 NSString *text = @"输入文本内容";
107 do {
108 fontSize = fontSize - 1;
109 UIFont *font =[UIFont fontWithName:@"Arial" size:fontSize];
110 //宽度与label的宽度一样,高度应高于label高度
111 CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100, 180)] lineBreakMode:NSLineBreakByCharWrapping];
112 height = size.height;
113 NSLog(@"height=%f,fontSize=%d,text=%@",height,fontSize,text);
114 } while (height > maxHeight&&fontSize>minFontSize);
115
116 UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 50)];
117 label.text =text;
118 if (fontSize ==9) {//判断字体是否小于最小字号,小于最小字号时就使用系统默认的缩略显示
119 label.font = [UIFont fontWithName:@"Arial" size:15];
120 }
121 else{
122 label.font = [UIFont fontWithName:@"Arial" size:fontSize];
123 label.lineBreakMode = NSLineBreakByCharWrapping;//实现文字多行显示
124 label.numberOfLines = 0;
125 }
126 [self.view addSubview:label];
127 */
128
129 // 设置背景图片
130 /* 方法一、设置背景图可以把一张大小与label一样的图放在label的后面一层,
131 然后把label的背景设置为透明,这样实现label有背景
132
133 UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 200, 400)];
134 UIImageView *imageView =[[UIImageView alloc]init];
135 imageView.frame =CGRectMake(50, 50, 200, 400);
136 UIImage *image=[UIImage imageNamed:@"1.jpg"];
137 imageView.image =image;//imageView会根据自身大小改变添加的图片的大小所以不需要额外设置image
138 label.backgroundColor = [UIColor clearColor];
139 label.text =@"hello world";
140 label.font = [UIFont systemFontOfSize:30];
141 label.textColor = [UIColor yellowColor];
142 [self.view addSubview:imageView];//添加的顺序不能错,否则图片会覆盖label
143 [self.view addSubview:label]; */
144
145 /* 方法二、用UIColor设置图片,然后把UIColor作为背景颜色,就可以实现label设置背景图
146
147 UIColor * color = [UIColor colorWithPatternImage:image];//image为需要添加的背景图
148 UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];
149 [label setBackgroundColor:color];
150 [self.view addSubview:label];
151
152 但这个方法有一个严重的缺陷,就是当背景图的尺寸与label大小不一致时,会出现背景图被部分截取或者平铺重复的情况,
153 所以更完善的方法是要先修改好背景图的大小与label大小一致再设置背景颜色。可以用下面的函数设置image尺寸
154
155 -(UIImage *)scaleImage:(UIImage *)img ToSize:(CGSize)itemSize{
156 UIImage *i;
157 // 创建一个bitmap的context,并把它设置成为当前正在使用的context
158 UIGraphicsBeginImageContext(itemSize);
159 CGRect imageRect=CGRectMake(0, 0, itemSize.width, itemSize.height);
160 // 绘制改变大小的图片
161 [img drawInRect:imageRect];
162 // 从当前context中创建一个改变大小后的图片
163 i=UIGraphicsGetImageFromCurrentImageContext();
164 // 使当前的context出堆栈
165 UIGraphicsEndImageContext();
166 // 返回新的改变大小后的图片
167 return i;
168 }
169
170 然后在主函数中调用即可
171
172 CGSize size= CGSizeMake(100, 200);
173 UIImage *image =[UIImage imageNamed:@"1.jpg"];
174 UIImage *laterImage =[self scaleImage:image ToSize:size];
175 UIColor * color = [UIColor colorWithPatternImage:laterImage];
176 UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];
177 [label setBackgroundColor:color];
178 [self.view addSubview:label]; */
179
180 //文本基线
181 label.baselineAdjustment=UIBaselineAdjustmentNone;//文本最低端与label中线对齐
182 label.baselineAdjustment=UIBaselineAdjustmentAlignBaselines;//文本最上端与中线对齐
183 label.baselineAdjustment=UIBaselineAdjustmentAlignCenters; //文本中线与label中线对齐
184
185 //自动收缩
186 label.minimumScaleFactor=0.5;
187
188 // 添加视图
189 [self.view addSubview:label];