iOS开发-UILabel

UILabel 的常见属性和方法


//创建UIlabel对象

UILabel* label = [[UILabel alloc] initWithFrame:self.view.bounds];

//设置显示文本

label.text = @"This is a UILabel Demo";

//设置阴影

label.shadowColor = [UIColor redColor];

label.shadowOffset = CGSizeMake(1.0,1.0);

//设置高亮 

label.highlighted = YES;

label.highlightedTextColor = [UIColre orangeColor];

//设置文本字体

label.font = [UIFont fontWithName:@"Arial" size:35];

//设置字体:粗体,正常的是 SystemFontOfSize     
    label1.font = [UIFont boldSystemFontOfSize:20]; 

//设置文本颜色

label.textColor = [UIColor yellowColor];

//设置文本水平显示位置(中心)

label.textAlignment = UITextAlignmentCenter;

//设置背景颜色

label.backgroundColor = [UIColor blueColor];

//设置单词折行方式

label.lineBreakMode = UILineBreakModeWordWrap;

//设置label是否可以显示多行,0则显示多行

label.numberOfLines = 0;

//设置字体大小适宜label宽度

label.adjustsFontSizeToFitWidth = YES;

//设置label中的文字是否可变,默认是YES

label.enabled = NO;

//根据内容大小,动态设置UILabel的高度 (ios 7  过期了,被其他方法替换掉了)

CGSize size = [label.text sizeWithFont:label.font constrainedToSize:self.view.bounds.size lineBreakMode:label.lineBreakMode];

CGRect rect = label.frame;

rect.size.height = size.height;

 label.frame = rect;  

//设置文字过长时的显示格式

6.lineBreakMode:设置标签文字过长时的显示方式

label.lineBreakMode = NSLineBreakByCharWrapping;以字符为显示单位显示,后面部分省略不显示。
label.lineBreakMode = NSLineBreakByClipping;剪切与文本宽度相同的内容长度,后半部分被删除。
label.lineBreakMode = NSLineBreakByTruncatingHead;前面部分文字以……方式省略,显示尾部文字内容。
label.lineBreakMode = NSLineBreakByTruncatingMiddle;中间的内容以……方式省略,显示头尾的文字内容。
label.lineBreakMode = NSLineBreakByTruncatingTail;结尾部分的内容以……方式省略,显示头的文字内容。
label.lineBreakMode = NSLineBreakByWordWrapping;以单词为显示单位显示,后面部分省略不显示。     
    label4.baselineAdjustment = UIBaselineAdjustmentNone;     
    //  typedef enum {     
    //      UIBaselineAdjustmentAlignBaselines,     
    //      UIBaselineAdjustmentAlignCenters,     
    //      UIBaselineAdjustmentNone,     
    //  } UIBaselineAdjustment;     


附上UILineBreakMode的各种情况,本人没有一一实验效果。

typedef enum {
   UILineBreakModeWordWrap = 0,
   UILineBreakModeCharacterWrap,
   UILineBreakModeClip,
   UILineBreakModeHeadTruncation,
   UILineBreakModeTailTruncation,
   UILineBreakModeMiddleTruncation,
} UILineBreakMode;


   UILineBreakModeWordWrap = 0,
   以单词为单位换行,以单位为单位截断。


   UILineBreakModeCharacterWrap,
   以字符为单位换行,以字符为单位截断。


   UILineBreakModeClip,
   以单词为单位换行。以字符为单位截断。


   UILineBreakModeHeadTruncation,
   以单词为单位换行。如果是单行,则开始部分有省略号。如果是多行,则中间有省略号,省略号后面有4个字符。


   UILineBreakModeTailTruncation,
   以单词为单位换行。无论是单行还是多行,都是末尾有省略号。


   UILineBreakModeMiddleTruncation,
   以单词为单位换行。无论是单行还是多行,都是中间有省略号,省略号后面只有2个字符。


特殊效果实现:

1. 竖排文字显示

要实现这个效果,网友给出了四种方法:


1.1 旋转UILabel,这种方法不可选,旋转之后每个字体的方向还是有问题。


1.2 每个文字加一个换行符,这是最方便和简单的实现方式。

label.text = @"请\n竖\n直\n方\n向\n排\n列";
label.numberOfLines = [label.text length];


1.3 创建新的canvas, 在UILabel上画出竖排文字。


1.4 重写UILabel类,添加竖排文字显示功能。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值