【发布时间】:2017-11-18 23:34:00
【问题描述】:
【问题讨论】:
-
是单行标签吗?
-
@dirtydanee --- 不.. 它的段落。
-
你的设计师应该定义字体大小和段落/行间距,而不是行高。
-
@dirtydanee .. 感谢您的建议.. 我刚刚上传了规范。其中提到了字体大小/和行高
【问题讨论】:
@bbjay 确实让我走上了正轨。
如果要得到Sketch的精确结果,公式为:
paragraphStyle .lineSpacing = sketchLineHeight - font.lineHeight
前提是给定字体sketchFontSize
【讨论】:
我发现以下公式对我很有效。 它将表单 Sketch 行高转换为 iOS 行距:
lineSpacing = sketchLineHeight - sketchFontSize - (font.lineHeight - font.pointSize)
在代码中,对于您的情况,这将是:
let font = UIFont.systemFont(ofSize: 18) // or whatever font you use
textLabel.font = font
let attributedString = NSMutableAttributedString(string: "your text")
let paragraphStyle = NSMutableParagraphStyle()
paragraphStyle.lineSpacing = 22 - 18 - (font.lineHeight - font.pointSize)
attributedString.addAttribute(.paragraphStyle, value: paragraphStyle, range: NSMakeRange(0, attributedString.length))
textLabel.attributedText = attributedString
【讨论】:
行高来自 CSS,因此您的设计师必须具有网页设计师背景。在移动平台上,我们不指定行高,而是line spacing。
一般来说,NSMutableParagraphStyle 提供了为 iOS 修改多行标签的功能。
NSMutableParagraphStyle 有一个名为maximumLineHeight 的属性,但这只会将最大行高设置为某个值,如果标签的包含会超过某个值。
要在 IB 中进行设置,您需要添加标签,并将 Text 属性更改为 Attributed。然后单击段落样式图标,然后设置标签的行距。查看设计,它大约是 2 点的行距,这是您所需要的。您可以要求您的设计师为您提供行距属性,也可以通过随机尝试不同的值来尝试找到正确的行距值。
【讨论】: