UILabel高度自适应

1.约束限定

对一个UILabel进行相关约束后,其中注意不要限制宽度和高度。如果限制宽度,在不同的设备上宽度约束明显会发生变化,比如限制一个UILabel宽度约束为400,而在iphone6下,iphone6的屏幕宽度是375,明显是不合理的。可以通过限制leading ,trailing等。高度可设可不设,不设的话直接setframe,设置的话需要更新约束。

2.宽度确定

既然是通过设置 左右边距 ,则label的宽度在各个iphone5尺寸都不一样。
宽度的确定通过 contentView.frame.size.width - UILabel左边的距离-UILabel右边的距离。尤其注意UILabel离最左边的距离会因为ios8 layout margin[http://stackoverflow.com/questions/25807545/what-is-constrain-to-margin-in-storyboard-in-xcode-6]的不同而发生变化,简单概括下,ios8下 iphone6s margin(8,20,8,20) 分别对应(上,左,下,右). iphone6 (8,16,8,16)
iphone5 (8,16,8,16) 如果setPreservesSuperviewLayoutMargins:NO. 则边距变为(8,8,8,8)这个应该是固定的。
也就解释了 当你设置某个控件leading 为10的时候为什么它的x值是18

3.使用的方法

通过给定一个矩形,宽为上述确定的宽度,高为max, 调用以下方法则可以返回计算得到的高度:
(void) sizeToFit : iOS 2.0;
或者
(rect) sizeThatFits: CGSize : iOS2.0
或者
(rect) boundingRectWithSize:CGSize Option attributes context : IOS7.0
目前使用的是boundingRectWithSize + sizeToFit ,通过判断是不是ios7.0以上的版本调用不同的方法。

4.提供的接口

类:CXCommon

方法
//根据字体行数自动调整对齐方式
+(void)resizeUILabelAlignment:(UILabel *)label judgeHeight:(CGFloat)judgeHeight fontSize:(CGFloat)fontSize;

//自适应高度,自动调整对齐方式 给定固定宽度,字体大小
+(void)resizeUILabelHeight:(UILabel *)label fixedWidth:(CGFloat)fixedWidth fontSize:(CGFloat)fontSize;

//默认对齐方式为左,给定固定宽度,字体大小
+(void)resizeUILabelHeightInAlignmentLeft:(UILabel *)label fixedWidth:(CGFloat)fixedWidth fontSize:(CGFloat)fontSize ;

调用举例:
[CXCommon resizeUILabelHeightInAlignmentLeft:self.detail fixedWidth:fixedWidth fontSize:14.f ];
注意在viewDidLoad执行,这样才能决定好height,从而调整rowHeight

稍后我会把Demo放上

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值