实现UILabel自适应高度的两种方式
2016-12-19 14:26
423 查看
1.sizeThatFits或者sizeToFit
2.boundingRectWithSize:(CGSize)size
options:(NSStringDrawingOptions)options
attributes:(NSDictionary<NSString *,id>
*)attributes context:(NSStringDrawingContext
*)context
ps:该方法跟第一种方法相比较有一个优势,它是被NSString对象调用的方法,因此可以直接用来计算NSString文字的宽度和高度,而sizeThatFits方法的调用对象是UIView,也就是说第二种方法的应用范围更广
pps:假如我们只是简单地想要label自适应高度,而不需要准确地计算label的frame,可以使用sizeToFit
ppps:Swift中String类型调用的方法为boundingRect,而且该方法没有提示,但是可以编译通过。
UILabel *label=[[UILabel alloc]init]; labell.font=[UIFont systemFontOfSize:11.0]; label.text = @"今天天气不错呢,准备到中国参加耐克的活动,中国的球迷准备好了吗?明天早上八点五棵松体育馆见,我爱你们!"; label.numberOfLines = 0; label.lineBreakMode = NSLineBreakByWordWrapping; CGSize size = [label sizeThatFits:CGSizeMake(200, MAXFLOAT)];//根据文字的长度返回一个最佳宽度和高度 label.frame = CGRectMake(0, 0, 200, size.height);//假如是自适应高度的话,就把宽度确定ps:在使用sizeThatFits方法之前,label.text属性必须要有值,不然无法计算
2.boundingRectWithSize:(CGSize)size
options:(NSStringDrawingOptions)options
attributes:(NSDictionary<NSString *,id>
*)attributes context:(NSStringDrawingContext
*)context
NSDictionary *dict = @{NSFontAttributeName : [UIFont systemFontOfSize:13.0]}; NSString *contentStr=@"今天天气不错呢,准备到中国参加耐克的活动,中国的球迷准备好了吗?明天早上八点五棵松体育馆见,我爱你们!"; CGSize size=[contentStr boundingRectWithSize:CGSizeMake(200, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:dict context:nil].size; UILabel *label=[[UILabel alloc]init]; labell.font=[UIFont systemFontOfSize:11.0]; label.numberOfLines = 0; label.text =contentStr; abel.frame = CGRectMake(0, 0, 200, size.height);
ps:该方法跟第一种方法相比较有一个优势,它是被NSString对象调用的方法,因此可以直接用来计算NSString文字的宽度和高度,而sizeThatFits方法的调用对象是UIView,也就是说第二种方法的应用范围更广
pps:假如我们只是简单地想要label自适应高度,而不需要准确地计算label的frame,可以使用sizeToFit
ppps:Swift中String类型调用的方法为boundingRect,而且该方法没有提示,但是可以编译通过。
相关文章推荐
- 实现自适应高度的 UITableViewCell 或 UILabel
- 实现自适应高度的 UITableViewCell 或 UILabel
- 用两种不同的方式来实现一个三列布局,其中左侧和右侧的部分宽度固定,中间部分宽度随浏览器宽度的变化而自适应变化
- CSS float的初步理解:用两种不同的方式来实现一个三列布局,其中左侧和右侧的部分宽度固定,中间部分宽度随浏览器宽度的变化而自适应变化
- 实现自适应高度的 UITableViewCell 或 UILabel
- 实现自适应高度的 UITableViewCell 或 UILabel
- cell高度自适应实现的最简单方式
- 简单实现ImageView宽度填满屏幕,高度自适应的两种方式
- 实现自适应高度的 UITableViewCell 或 UILabel
- iOS开发-使用storyboard实现UILabel的自适应高度(iOS8)
- 实现自适应高度的 UITableViewCell 或 UILabel
- iOS开发-使用storyboard实现UILabel的自适应高度(iOS8)
- Jquery与JS两种方法仿twitter/新浪微博 高度自适应无缝滚动实现代码
- Javascript 瀑布流实现的两种方式:固定列数的浮动布局与绝对定位自适应宽度
- IOS7.0 UILabel实现自适应高度的新方法
- 实现UILabel高度和宽度的自适应和UITextView的高度自适应
- 设置背景图片的两种方式,并解决手机端背景图片高度自适应问题
- 用两种不同的方式来实现一个三列布局,其中左侧和右侧的部分宽度固定,中间部分宽度随浏览器宽度的变化而自适应变化
- 实现UILabel高度和宽度的自适应和UITextView的高度自适应
- 实现自适应高度的 UITableViewCell 或 UILabel