iOS设置UILabel最大宽度(preferredMaxLayoutWidth)

iOS设置UILabel最大宽度(preferredMaxLayoutWidth),第1张

在开发项目的时候,经常遇到需要适配uilabel的宽度的地方。如果label后面不需要紧跟其他的UI元素还可以,只需要设置一个label的宽度,然后字体靠左对齐就可以了。

但是,如果像图中这样依然采用这种方式,则会导致右边的元素不会紧跟着文字,达不到预想的效果。

这时preferredMaxLayoutWidth就可以发挥它的作用了。

// Support for constraint-based layout (auto layout)

// If nonzero, this is used when determining -intrinsicContentSize for multiline labels

@property(nonatomic) CGFloat preferredMaxLayoutWidth NS_AVAILABLE_IOS(6_0)

文档中说的大概意思就是,当约束基于auto layout时,如果这个值不是0,这个属性就可以用来固定多行label的宽度。

也就是说当文本很长的时候,可以通过这个属性来设置label的最大宽度,使label通过更多的行数来展示全部文本内容。

那么问题来了,我们要的效果是限制但行文本的最大宽度,而不是让文本多行展示。

这个地方我试过将label的numberOfLines设置为1,但是此时设置的最大宽度不起作用了。(毕竟preferredMaxLayoutWidth说明是约束多行文本的最大宽度。。)

所以,我又想到了一个曲线救国的办法,在xib中为label的高度加一个只有一行文字时高度的约束,这时经过我的测试就达到了预期的效果:只展示单行文字,并且label不会超过设定的最大宽度,文字长度较短时,label也是对应文本的相应宽度。完美!

(文章写的很少,有些啰嗦,见谅。)

之前的方式一般是这样的:

label.layer.cornerRadius = 2

label.layer.masksToBounds = YES / label.layer.clipToBounds = YES

这样会出现离屏渲染,如果是每个TableViewCell设置一些圆角,就会使列表滑动起来有明显卡顿。

正确方式:

摒弃label.layer.masksToBounds = YES / label.layer.clipToBounds = YES方法。

情形1:

 对于不需要设置背景色的情况,只设置borderWidth、borderColor,cornerRadius,就可以实现圆角功能。

情形2:

 对于设置背景色的情况,不去设置label的backgroundColor,而是直接设置label.layer.backgroundColor,这样就可以实现单独设置cornerRadius,显示圆角的效果。

备注:

对于情形2,设置label的backgroundColor同时设置cornerRadius是不能正常显示圆角的,再同时设置borderWidth、borderColor也不行。原因是:UILabel设置backgroundColor的行为,不再是设定layer的背景色而是为contents设置背景色。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/tougao/11016756.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存