iOS控件学习笔记 - UILabel
UILabel *lbl = [[UILabel alloc]init];
lbl.frame = CGRectMake(100,100,100,20);
lbl.textColor = [UIColor blackColor];
lbl.text = @"测试";
[self.view addSubview:lbl];
设置文本对齐方式
lbl.textAlignment = NSTextAlignmentLeft;
typedef NS_ENUM(NSInteger, NSTextAlignment) {
NSTextAlignmentLeft = 0, // 居左
NSTextAlignmentCenter = 1, // 居中
NSTextAlignmentRight = 2, // 居右
NSTextAlignmentJustified = 3, //段落中的最后一行是自然对齐的
NSTextAlignmentNatural = 4, //默认对齐方式 TODO 测试
} NS_ENUM_AVAILABLE_IOS(6_0);
设置文本行数
lbl.numberOfLines = 0; //不限制行数
lbl.numberOfLines = n; //n行
设置文本自适应
lbl.adjustsFontSizeToFitWidth = YES;//字体大小随着控件宽度变化
[lbl sizeToFit];//控件大小随着字体大小变化。
设置用户是否可以响应用户操作
lbl.userInteractionEnabled = YES;
设置文本的基线位置
//文本最上端与Label中线对齐,默认值
lbl.baselineAdjustment = UIBaselineAdjustmentAlignBaselines;
//文本中线与Label中线对齐
lbl.baselineAdjustment = UIBaselineAdjustmentAlignCenters;
//文本最底端与Label中线对齐
lbl.baselineAdjustment = UIBaselineAdjustmentNone;
设置文字过长时的显示格式
lbl.lineBreakMode = NSLineBreakByWordWrapping;
typedef NS_ENUM(NSInteger, NSLineBreakMode) {
NSLineBreakByWordWrapping = 0, //以单词为边界
NSLineBreakByCharWrapping, //以字符为边界
NSLineBreakByClipping, //简单剪裁,到边界为止
NSLineBreakByTruncatingHead, //按照"……文字"显示
NSLineBreakByTruncatingTail, //按照"文字……"显示
NSLineBreakByTruncatingMiddle //按照"文字……文字"显示
} NS_ENUM_AVAILABLE(10_0, 6_0);
富文本显示方式
设置文本行间距
NSString * str = @"这是一段测试性的话语,字打的太少会看不出来结果。多打几行,看看处理后的效果。这是一段测试性的话语,字打的太少会看不出来结果。多打几行,看看处理后的效果。这是一段测试性的话语,字打的太少会看不出来结果。多打几行,看看处理后的效果。这是一段测试性的话语,字打的太少会看不出来结果。多打几行,看看处理后的效果。";
UILabel * lbl = [[UILabel alloc]initWithFrame:CGRectMake(20, 100, 280, 100)];
lbl.numberOfLines = 0;
lbl.backgroundColor = [UIColor orangeColor];
lbl.font = [UIFont systemFontOfSize:16];
lbl.textColor = [UIColor blackColor];
NSMutableParagraphStyle * pStryle = [[NSMutableParagraphStyle alloc] init];
[pStryle setLineSpacing:20];//设置行间距
NSMutableAttributedString * attrStr = [[NSMutableAttributedString alloc] initWithString:str];
[attrStr addAttribute:NSParagraphStyleAttributeName value:pStryle range:NSMakeRange(0, [str length])];
[lbl setAttributedText:attrStr];
[lbl sizeToFit];//设置控件大小自适应变化
[self.view addSubview:lbl];
效果如下
设置控件是否可编辑
lbl.enabled = NO;