设置UILabel行距


Answers:


122

编辑:显然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的老attributedStringWithString做同样的事情,但现在已被弃用。

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

简短答案:您不能。要更改文本行之间的间距,您将必须继承UILabel并滚动自己的文本,drawTextInRect创建多个标签或使用不同的字体(也许已针对特定的行高对其进行了编辑,请参见Phillipe的答案)。

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

,也没有间距参数UILabel

我对UILabel的行为并不特别满意,因此建议您编写自己的子类或使用3rd-party库。这将使行为独立于您的字体选择,并成为最可重用的解决方案。

我希望有在更多的灵活性UILabel,并且我很乐意被证明是错误的!


1
我通过对UILabel进行子类化来完成此操作,其基本思想是将标签文本分为令牌,然后标识每个令牌的长度,为每个令牌创建一个单独的标签,然后一个接一个地附加。而已。
Matrix

3
说谎!;)您可以修补字体文件以更改行高-请参阅此页面上的答案。
菲利普(Philippe)2012年

我被认为可以使用NSAttributedString做到这一点。如果在iOS 6之前的版本中需要带有属性字符串的标签,请查看OHAttributedLabel
Spencer Williams

如果使用iOS> = 6,请使用NSAttributesString进行处理。示例
d.ennis 2013年

这很简单而且工作正常。
R. Mohan

75

从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 ;

1
谢谢!我会添加使用AttributedString禁用标签文本对齐方式,因此您必须将其添加到段落样式。
cyborg86pl 2013年

56

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

重复问题


10
但是,在Xcode 6.1.1中,选择标签并在属性面板中更改行值将导致面板闪烁并锁定应用程序。我只能通过强制退出Xcode退出面板。
izk 2014年

4
动画竖起大拇指
Tieme 2014年

1
在7.1版中,面板会滑动,并且对运行时间没有任何影响。不得不在代码中做到这一点。
MiguelSlv 2015年

440瓦电刚刚通过我的面板;)
萨拉斯朗特(Sarasranglt

23

从Interface Builder:

在此处输入图片说明

以编程方式:

迅捷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

需要通过只有一个arguement lineSpacing或multipleLineheight,T可以通过两种arguenemt其他明智的没有结果就来了,我想
Arpit乙Parekh的

16

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

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


超酷!这些OS X字体工具也适用于我的OTF字体(尽管它仅指定TTF ...)。我的字体的行高为1000(!),我将其更改为0,瞧。每行文字下方都有数英里的空白空间。
Jonny 2012年

2
我不敢相信这是最好的解决方案(没有冒犯!),但是到目前为止,这是最简单的解决方案。我使用了免费的(Windows)软件Type Light(在Font | Metrics | Advanced下,您可以修改lineGap)来编辑我的字体。它还允许您“重命名”字体,我无法弄清楚如何使用Philippe提到的工具。
Kirk Woll

这真是太棒了@Philippe!谢谢你的帖子!
罗比

另请参阅我对类似问题的解答以获取更多详细信息:stackoverflow.com/a/19553827/201828
phatmann

@iamjustaprogrammer再次在线。
Matt B.




2

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

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

0

当然,如果您以编程方式传递字符串,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;
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.