设置 UILabel 行距

Posted

技术标签:

【中文标题】设置 UILabel 行距【英文标题】:Set UILabel line spacing 【发布时间】:2011-04-22 06:51:30 【问题描述】:

如何修改多行UILabel 中的行间距(行间距)?

【问题讨论】:

【参考方案1】:

编辑:显然NSAttributedString 会在 ios 6 及更高版本上做到这一点。不要使用NSString 来设置标签的文本,而是创建一个NSAttributedString,在其上设置属性,然后将其设置为标签上的.attributedText。你想要的代码是这样的:

NSMutableAttributedString* attrString = [[NSMutableAttributedString  alloc] initWithString:@"Sample text"];
NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init];
[style setLineSpacing:24];
[attrString addAttribute:NSParagraphStyleAttributeName
    value:style
    range:NSMakeRange(0, strLength)];
uiLabel.attributedText = attrString;

NSAttributedString 的旧的 attributesStringWithString 做了同样的事情,但现在 已被弃用。

由于历史原因,这是我原来的答案:

简答:你不能。要更改文本行之间的间距,您必须继承 UILabel 并滚动您自己的 drawTextInRect,创建多个标签,或使用不同的字体(可能为特定的行高编辑一个字体,请参阅 Phillipe 的回答)。

长答案:在印刷和在线世界中,文本行之间的空间被称为“领先”(与“标题”押韵,来自几十年前使用的铅金属)。 Leading 是 UIFont 的只读属性,在 4.0 中已弃用并由 lineHeight 取代。据我所知,没有办法创建具有特定参数集的字体,例如lineHeight;您可以获得系统字体和您添加的任何自定义字体,但一旦安装就无法调整它们。

UILabel 中也没有间距参数。

我对@9​​87654335@ 的行为不是特别满意,所以我建议编写自己的子类或使用第 3 方库。这将使行为独立于您的字体选择,并成为最可重用的解决方案。

我希望UILabel 有更多的灵活性,我很高兴被证明是错误的!

【讨论】:

我已经用子类UILabel做到了,基本上想法是将标签文本分成令牌,然后每个令牌的标识长度,为每个令牌创建一个单独的标签并一个接一个地附加。就是这样。 谎言! ;) 您可以修补字体文件以更改行高 - 请参阅我在此页面上的答案。 我是led to believe 有一种方法可以使用 NSAttributedString 来实现。如果您在 iOS 6 之前需要带有属性字符串的标签,请查看OHAttributedLabel。 如果您使用 iOS >= 6,请使用 NSAttributesString。Example 这很简单,工作正常。【参考方案2】:

我找到了像这样的第 3 方库:

https://github.com/Tuszy/MTLabel

成为最简单的解决方案。

【讨论】:

【参考方案3】:

这家伙创建了一个类来获取行高(不使用 CoreText,作为 MTLabel 库):https://github.com/LemonCake/MSLabel

【讨论】:

【参考方案4】:

我的解决方案是修补字体文件本身并确定其行高。 http://mbauman.net/geek/2009/03/15/minor-truetype-font-editing-on-a-mac/

我必须修改“hhea”块中的“lineGap”、“ascender”、“descender”(如博客示例中所示)。

【讨论】:

超酷!那些 OS X 字体工具也适用于我的 OTF 字体(尽管它只指定 TTF ......)。我的字体的行高为 1000(!),我将其更改为 0,瞧。每行文字下方都有数英里的空白区域。 我不敢相信这是最好的解决方案(无意冒犯!),但它是迄今为止最简单的。我使用免费(Windows)软件Type Light(在字体|度量|高级下你可以修改lineGap)来编辑我的字体。它还允许您“重命名”字体,我无法弄清楚如何使用 Philippe 提到的工具。 这太棒了@Philippe!感谢您的帖子! 另请参阅我对类似问题的回答以了解更多详情:***.com/a/19553827/201828 @iamjustaprogrammer 又上线了。【参考方案5】:

从 ios 6 开始,您可以在 UILabel 中设置属性字符串:

NSString *labelText = @"some text"; 
NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:labelText];
NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc] init];
[paragraphStyle setLineSpacing:40];
[attributedString addAttribute:NSParagraphStyleAttributeName value:paragraphStyle range:NSMakeRange(0, [labelText length])];
cell.label.attributedText = attributedString ;

【讨论】:

谢谢!我要补充一点,使用 AttributedString 会禁用例如标签的文本对齐方式,因此您必须将其添加到段落样式中。【参考方案6】:

我发现的最好的东西是:https://github.com/mattt/TTTAttributedLabel

它是一个 UILabel 子类,因此您可以将其放入,然后更改行高:

myLabel.lineHeightMultiple = 0.85;
myLabel.leading = 2;

【讨论】:

【参考方案7】:

您可以控制情节提要中的行距:

duplicate question

【讨论】:

但是在 Xcode 6.1.1 中选择标签并更改属性面板中的行值将导致面板闪烁并锁定应用程序。我只能通过强制退出 Xcode 来退出面板。 为动画点赞 在 7.1 版中,面板会闪烁,并且对运行时间没有任何影响。必须在代码中完成。 440 瓦的电流刚刚通过我的面板;)【参考方案8】:

当然,如果您以编程方式传递字符串,Mike 的回答将不起作用。在这种情况下,您需要传递一个属性字符串并更改其样式。

NSMutableAttributedString * attrString = [[NSMutableAttributedString alloc] initWithString:@"Your \nregular \nstring"];
NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init];
[style setLineSpacing:4];
[attrString addAttribute:NSParagraphStyleAttributeName
                   value:style
                   range:NSMakeRange(0, attrString.length)];
_label.attributedText = attrString;

【讨论】:

【参考方案9】:

这里有一些快速代码供您以编程方式设置行距

let label = UILabel()

let attributedText = NSMutableAttributedString(string: "Your string")
let paragraphStyle = NSMutableParagraphStyle()

//SET THIS:
paragraphStyle.lineSpacing = 4
//OR SET THIS:
paragraphStyle.lineHeightMultiple = 4

//Or set both :)

let range = NSMakeRange(0, attributedText.length)
attributedText.addAttributes([NSParagraphStyleAttributeName : paragraphStyle], range: range)
label.attributedText = attributedText

【讨论】:

【参考方案10】:

来自界面生成器:

以编程方式:

斯威夫特 4

使用标签扩展

extension UILabel 

    func setLineSpacing(lineSpacing: CGFloat = 0.0, lineHeightMultiple: CGFloat = 0.0) 

        guard let labelText = self.text else  return 

        let paragraphStyle = NSMutableParagraphStyle()
        paragraphStyle.lineSpacing = lineSpacing
        paragraphStyle.lineHeightMultiple = lineHeightMultiple

        let attributedString:NSMutableAttributedString
        if let labelattributedText = self.attributedText 
            attributedString = NSMutableAttributedString(attributedString: labelattributedText)
         else 
            attributedString = NSMutableAttributedString(string: labelText)
        

        // Line spacing attribute
        attributedString.addAttribute(NSAttributedStringKey.paragraphStyle, value:paragraphStyle, range:NSMakeRange(0, attributedString.length))

        self.attributedText = attributedString
    

现在调用分机功能

let label = UILabel()
let stringValue = "How to\ncontrol\nthe\nline spacing\nin UILabel"

// Pass value for any one argument - lineSpacing or lineHeightMultiple
label.setLineSpacing(lineSpacing: 2.0) .  // try values 1.0 to 5.0

// or try lineHeightMultiple
//label.setLineSpacing(lineHeightMultiple = 2.0) // try values 0.5 to 2.0

或使用标签实例(只需复制并执行此代码即可查看结果)

let label = UILabel()
let stringValue = "Set\nUILabel\nline\nspacing"
let attrString = NSMutableAttributedString(string: stringValue)
var style = NSMutableParagraphStyle()
style.lineSpacing = 24 // change line spacing between paragraph like 36 or 48
style.minimumLineHeight = 20 // change line spacing between each line like 30 or 40

// Line spacing attribute
attrString.addAttribute(NSAttributedStringKey.paragraphStyle, value: style, range: NSRange(location: 0, length: stringValue.characters.count))

// Character spacing attribute
attrString.addAttribute(NSAttributedStringKey.kern, value: 2, range: NSMakeRange(0, attrString.length))

label.attributedText = attrString

斯威夫特 3

let label = UILabel()
let stringValue = "Set\nUILabel\nline\nspacing"
let attrString = NSMutableAttributedString(string: stringValue)
var style = NSMutableParagraphStyle()
style.lineSpacing = 24 // change line spacing between paragraph like 36 or 48
style.minimumLineHeight = 20 // change line spacing between each line like 30 or 40
attrString.addAttribute(NSParagraphStyleAttributeName, value: style, range: NSRange(location: 0, length: stringValue.characters.count))
label.attributedText = attrString

【讨论】:

只需要通过一个参数 lineSpacing 或 multipleLineheight ,不能同时通过两个参数否则不会有结果,我想

以上是关于设置 UILabel 行距的主要内容,如果未能解决你的问题,请参考以下文章

UILabel中如何控制行距

使用 lineHeightMultiple 控制行间行距时,如何在 UITableViewCell 中垂直对齐我的 UILabel?

UILabel - 设置旋转框架

将 UILabel 文本设置为粗体 [重复]

如何设置UIView高度等于两个子视图UILabel的最大值?

iOS UILabel 设置行高