Як збільшити міжрядковий інтервал у UILabel у Swift


94

У мене є мітка, яка має кілька рядків тексту, і я хочу збільшити інтервал між рядками. Є подібні запитання, які задають інші, але рішення не вирішують мої проблеми. Також мій ярлик може містити або не містити абзаців. Я новачок у Swift. Чи є рішення за допомогою розкадровки? Або лише через NSAttributedStringйого можливе?

Відповіді:


175

Програматично додайте LineSpacing до вашого, UILabelвикористовуючи наступний фрагмент.

Раніше версія Swift

let attributedString = NSMutableAttributedString(string: "Your text")

// *** Create instance of `NSMutableParagraphStyle`
let paragraphStyle = NSMutableParagraphStyle()

// *** set LineSpacing property in points ***
paragraphStyle.lineSpacing = 2 // Whatever line spacing you want in points

// *** Apply attribute to string ***
attributedString.addAttribute(NSParagraphStyleAttributeName, value:paragraphStyle, range:NSMakeRange(0, attributedString.length))

// *** Set Attributed String to your label ***
label.attributedText = attributedString

Свіфт 4.0

let attributedString = NSMutableAttributedString(string: "Your text")

// *** Create instance of `NSMutableParagraphStyle`
let paragraphStyle = NSMutableParagraphStyle()

// *** set LineSpacing property in points ***
paragraphStyle.lineSpacing = 2 // Whatever line spacing you want in points

// *** Apply attribute to string ***
attributedString.addAttribute(NSAttributedStringKey.paragraphStyle, value:paragraphStyle, range:NSMakeRange(0, attributedString.length))

// *** Set Attributed String to your label ***
label.attributedText = attributedString

Свіфт 4.2

let attributedString = NSMutableAttributedString(string: "Your text")

// *** Create instance of `NSMutableParagraphStyle`
let paragraphStyle = NSMutableParagraphStyle()

// *** set LineSpacing property in points ***
paragraphStyle.lineSpacing = 2 // Whatever line spacing you want in points

// *** Apply attribute to string ***
attributedString.addAttribute(NSAttributedString.Key.paragraphStyle, value:paragraphStyle, range:NSMakeRange(0, attributedString.length))

// *** Set Attributed String to your label ***
label.attributedText = attributedString

3
Це показує помилку "Значення типу 'NSAttributedString' не має члена 'addAttribute'".
Sneha

2
Нам потрібно використовувати NSMutableAttributedStringзамість цього NSAttributedString. Я оновив asnwer.
Діпен Панчасара

1
Робота зі спеціальними шрифтами Також чудово @ Dipen Panchasara
Abdul Karim

7
Не знаю чому, але, як на мене, це працює лише якщо встановити інтервал між рядками> = 1, я спробував встановити 0,5 / 0,75, це не має ефекту
Аксімем

2
Не потрібно NSMutableAttributedString. Можна використовуватиNSAttributedString(string: "Your text", attributes: [NSAttributedString.Key.paragraphStyle : paragraphStyle])
bauerMusic

101

Із Interface Builder:

введіть тут опис зображення

Програмно:

SWift 4 і 4.2

Використання розширення етикетки

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)
        }

        // (Swift 4.2 and above) Line spacing attribute
        attributedString.addAttribute(NSAttributedString.Key.paragraphStyle, value:paragraphStyle, range:NSMakeRange(0, attributedString.length))


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

        self.attributedText = attributedString
    }
}

Тепер викличте функцію розширення

let label = UILabel()
let stringValue = "Set\nUILabel\nline\nspacing"

// 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

"NSAttributedStringKey.paragraphStyle" мала помилку, я замість цього використав "NSParagraphStyleAttributeName".
Ахмадреза

@Alfi - це різниця в мовній версії Swift. Швидка мова вашого проекту. версія може бути швидкою 3.x, і ось відповіді на обидві версії. Спробуйте скористатися кодом Swift 3.
Крунал

Привіт @krunal, я встановив Linespacing і LineHeight в інтерфейсі, і я встановив текст в UILabel програмно, але він не працює. якщо я додаю текст в Інтерфейс, це працює. Ви можете допомогти мені за це Дякую, і я також встановив attributedText та текст в UILabel, але такий підхід для мене не працює.
Йогеш Патель

рішення для побудови інтерфейсу призначене лише для статичного тексту. коли ми додаємо атрибутивний рядок у код, той атрибут, який додається із конструктора інтерфейсу, не застосовується.
Йодагама

66

Ви можете керувати інтервалом між рядками storyboard.

введіть тут опис зображення

Те саме питання.


8
Я насправді спробував це. Але це не працює. Також це не корисно для користувацьких шрифтів.
Sneha

Якщо ви стикаєтесь з неправильним вирівнюванням у користувацьких шрифтах, спробуйте оновити ascenderвластивість, як зазначено тут .
pkc456

1
Це не проблема неправильного вирівнювання. Я не можу вибрати власний шрифт із рішенням, яке ви сказали @ pkc456
Sneha

Це не проблема неправильного вирівнювання. Я не міг вибрати свій власний шрифт, але тепер я вирішив це, додавши свій шрифт через налаштування окремо в Attributed. . Але все ж інтервал залишається тим же @ pkc456
Sneha

15
Це лише для статичного тексту. Спробуйте додати текст програмно. Це не спрацює.
Sneha

11

Нещодавнє рішення для Swift 5.0

private extension UILabel {

    // MARK: - spacingValue is spacing that you need
    func addInterlineSpacing(spacingValue: CGFloat = 2) {

        // MARK: - Check if there's any text
        guard let textString = text else { return }

        // MARK: - Create "NSMutableAttributedString" with your text
        let attributedString = NSMutableAttributedString(string: textString)

        // MARK: - Create instance of "NSMutableParagraphStyle"
        let paragraphStyle = NSMutableParagraphStyle()

        // MARK: - Actually adding spacing we need to ParagraphStyle
        paragraphStyle.lineSpacing = spacingValue

        // MARK: - Adding ParagraphStyle to your attributed String
        attributedString.addAttribute(
            .paragraphStyle,
            value: paragraphStyle,
            range: NSRange(location: 0, length: attributedString.length
        ))

        // MARK: - Assign string that you've modified to current attributed Text
        attributedText = attributedString
    }

}

І використання:

let yourLabel = UILabel()
let yourText = "Hello \n world \n !"
yourLabel.text = yourText
yourLabel.addInterlineSpacing(spacingValue: 1.5)

Це, звичайно, буде працювати, лише якщо ви використовуєте, UILabel.textа ніUILabel.attributedText
JeroenJK

9

Ви можете використовувати це багаторазове розширення:

extension String {

func lineSpaced(_ spacing: CGFloat) -> NSAttributedString {
    let paragraphStyle = NSMutableParagraphStyle()
    paragraphStyle.lineSpacing = spacing
    let attributedString = NSAttributedString(string: self, attributes: [NSAttributedString.Key.paragraphStyle: paragraphStyle])
    return attributedString
}
}

5

Свіфт 4 і Свіфт 5

extension NSAttributedString {
    func withLineSpacing(_ spacing: CGFloat) -> NSAttributedString {


        let attributedString = NSMutableAttributedString(attributedString: self)
        let paragraphStyle = NSMutableParagraphStyle()
        paragraphStyle.lineBreakMode = .byTruncatingTail
        paragraphStyle.lineSpacing = spacing
        attributedString.addAttribute(.paragraphStyle,
                                      value: paragraphStyle,
                                      range: NSRange(location: 0, length: string.count))
        return NSAttributedString(attributedString: attributedString)
    }
}

Як користуватись

    let example = NSAttributedString(string: "This is Line 1 \nLine 2 \nLine 3 ").withLineSpacing(15)
    testLabel.attributedText = example

Приклад


Дивовижність! Врятував мій час!
Codetard

4

Відповідь Діпена оновлено для Swift 4

let attr = NSMutableAttributedString(string: today)
let paragraphStyle = NSMutableParagraphStyle()
paragraphStyle.lineSpacing = 2
attr.addAttribute(.paragraphStyle, value: paragraphStyle, range: NSMakeRange(0, attr.length))
label.attributedText = attr;

1
//Swift 4:
    func set(text:String,
                         inLabel:UILabel,
                         withLineSpacing:CGFloat,
                         alignment:NSTextAlignment){
            let paragraphStyle = NSMutableParagraphStyle()
            paragraphStyle.lineSpacing = withLineSpacing
            let attrString = NSMutableAttributedString(string: text)
            attrString.addAttribute(NSAttributedStringKey.paragraphStyle,
                                    value:paragraphStyle,
                                    range:NSMakeRange(0, attrString.length))
            inLabel.attributedText = attrString
            inLabel.textAlignment = alignment
          }
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.