UILabelの行間隔を設定する


回答:


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か、複数のラベルを作成するか、別のフォントを使用する必要があります(おそらく、特定の行の高さ用に編集されたフォントです。フィリップの回答を参照してください)。

長い答え:印刷物やオンラインの世界では、テキストの行間のスペースは「リーディング」(「見出し」の付いた韻で、数十年前に使用されていた鉛金属に由来します)として知られています。Leadingはの読み取り専用プロパティでありUIFont、4.0で廃止され、に置き換えられましたlineHeight。私の知る限り、次のような特定のパラメータセットを使用してフォントを作成する方法はありませんlineHeight。システムフォントと追加したカスタムフォントを取得しますが、インストールするとそれらを調整することはできません。

にも間隔パラメータはありませんUILabel

私はUILabelの振る舞いに特に満足しているわけではないので、独自のサブクラスを記述するか、サードパーティのライブラリを使用することをお勧めします。これにより、フォントの選択とは関係なく動作が行われ、最も再利用可能なソリューションになります。

もっと柔軟性があったらいいのにUILabelたら良かったのですが、間違いを証明できて嬉しいです!


1
UILabelをサブクラス化してそれを実行しました。基本的には、ラベルテキストをトークンに分割し、各トークンのIDの長さを確認し、各トークンに個別のラベルを作成して、次々に追加することです。それでおしまい。
マトリックス

3
嘘!;)フォントファイルにパッチを適用して行の高さを変更できます-このページの私の回答を参照してください。
フィリップ

私はよ信じるように導か NSAttributedStringでこれを行う方法があります。iOS 6より前の属性付き文字列のラベルが必要な場合は、OHAttributedLabelをチェックしてください
スペンサーウィリアムズ

iOS> = 6を使用している場合は、NSAttributesStringを使用してください。
d.ennis

これはシンプルで正常に機能します。
R.モハン

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 14

4
アニメーションのいい

1
バージョン7.1では、パネルが点滅し、実行時間に影響を与えません。コードでそれをしなければなりませんでした。
MiguelSlv 2015年

440ワットの電力が私のパネルを
通り過ぎました

23

Interface Builderから:

ここに画像の説明を入力してください

プログラム的に:

SWift 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を渡す必要があり、両方arguenemt他の賢明なしの結果が来る渡すtはできる、私は思う
Arpit B 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に変更して出来上がりです。各行のテキストの下に何マイルも空のスペースがありました。
ジョニー

2
これが最善の解決策であるとは信じられません(問題はありません!)が、これは非常に簡単です。私は無料の(Windows)ソフトウェアType Light(およびFont | Metrics | AdvancedでlineGapを変更できます)を使用してフォントを編集しました。また、フォントの「名前を変更」することもできますが、Philippe氏が言及したツールの使用方法はわかりませんでした。
Kirk Woll、

これは素晴らしい@Philippeです!投稿ありがとうございます!
ロビー

また、より多くの詳細について同様の質問に対する私の答えを参照してください。stackoverflow.com/a/19553827/201828
phatmann

@iamjustaprogrammer再びオンラインになりました。
マット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

もちろん、プログラムで文字列を渡した場合、マイクの答えは機能しません。この場合、属性付きの文字列を渡して、そのスタイルを変更する必要があります。

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;
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.