OStack程序员社区-中国程序员成长平台

标题: ios - Wordwrap 与换行 UIButton 拉伸(stretch) [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-12 16:56
标题: ios - Wordwrap 与换行 UIButton 拉伸(stretch)

我有一个 UIButton,我需要能够将其标签设置为任何文本,因此它需要垂直拉伸(stretch)。

使用 \n 字符设置文本时,UIButton 会正确展开:

self.myButton.titleLabel.textAlignment = NSTextAlignmentCenter;
self.myButton.titleLabel.lineBreakMode = NSLineBreakByWordWrapping;
self.myButton.titleLabel.numberOfLines = 0;
[self.myButton setTitle"Lorem ipsum dolor sit amet, consectetuer \nadipiscing elit, sed diam nonummy nibh \neuismod tincidunt ut laoreet dolore \nmagna aliquam erat volutpat. \nUt wisi enim ad minim veniam, \nquis nostrud exerci tation ullamcorper \nsuscipit lobortis nisl ut aliquip ex \nea commodo consequat." forState:UIControlStateNormal];

enter image description here

但是当我没有任何 \n 而是让标签根据内容自行换行时,这些行似乎对 UIButton高度

self.myButton.titleLabel.textAlignment = NSTextAlignmentCenter;
self.myButton.titleLabel.lineBreakMode = NSLineBreakByWordWrapping;
self.myButton.titleLabel.numberOfLines = 0;
[self.myButton setTitle"Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat." forState:UIControlStateNormal];

enter image description here

UIButton 或其 UILabel 上是否有控制此行为的配置,或者这是 iOS 错误? (在 iOS 9.1 上运行)

注意:我对每次更改文本时手动重新计算 UIButton 的帧大小并不感兴趣,我想知道如果 UIButton 上有自动布局约束或配置属性以获得正确的行为



Best Answer-推荐答案


您需要创建一个 UIButton 的子类,在其中覆盖 intrinsicContentSize:

@implementation HeightExpandingButton

- (CGSize)intrinsicContentSize {
    CGFloat width = self.bounds.size.width;
    CGSize labelSize = [self.titleLabel sizeThatFits:CGSizeMake(width, 100000)];
    labelSize.width = width;
    return labelSize;
}

@end

结果:

demo

关于ios - Wordwrap 与换行 UIButton 拉伸(stretch),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33522032/






欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) Powered by Discuz! X3.4