回答:
sectionLabel.font = [UIFont fontWithName:@"TrebuchetMS-Bold" size:18];
'fontWithName'属性の代わりに設定できるフォント名のリストがあります。リンクはこちらです
フォント名をいじらないでください。フォント記述子を使用すると、名前は必要ありません。
UILabel * label = [[UILabel alloc] init]; // use your label object instead of this
UIFontDescriptor * fontD = [label.font.fontDescriptor
fontDescriptorWithSymbolicTraits:UIFontDescriptorTraitBold
| UIFontDescriptorTraitItalic];
label.font = [UIFont fontWithDescriptor:fontD size:0];
size:0
「サイズをそのまま維持する」ことを意味します
Swiftを使用して、次の拡張機能を試してください。
extension UIFont {
func withTraits(traits:UIFontDescriptorSymbolicTraits...) -> UIFont {
let descriptor = self.fontDescriptor()
.fontDescriptorWithSymbolicTraits(UIFontDescriptorSymbolicTraits(traits))
return UIFont(descriptor: descriptor, size: 0)
}
func boldItalic() -> UIFont {
return withTraits(.TraitBold, .TraitItalic)
}
}
次に、次のように使用します。
myLabel.font = myLabel.font.boldItalic()
または、Condensedのような追加の特性を追加します。
myLabel.font = myLabel.font.withTraits(.TraitCondensed, .TraitBold, .TraitItalic)
extension UIFont {
var bold: UIFont {
return with(traits: .traitBold)
} // bold
var italic: UIFont {
return with(traits: .traitItalic)
} // italic
var boldItalic: UIFont {
return with(traits: [.traitBold, .traitItalic])
} // boldItalic
func with(traits: UIFontDescriptorSymbolicTraits) -> UIFont {
guard let descriptor = self.fontDescriptor.withSymbolicTraits(traits) else {
return self
} // guard
return UIFont(descriptor: descriptor, size: 0)
} // with(traits:)
} // extension
次のように使用します。
myLabel.font = myLabel.font.bold
または
myLabel.font = myLabel.font.italic
または
myLabel.font = myLabel.font.with(traits: [ .traitBold, .traitCondensed ])
extension UIFont {
var bold: UIFont {
return with(.traitBold)
}
var italic: UIFont {
return with(.traitItalic)
}
var boldItalic: UIFont {
return with([.traitBold, .traitItalic])
}
func with(_ traits: UIFontDescriptor.SymbolicTraits...) -> UIFont {
guard let descriptor = self.fontDescriptor.withSymbolicTraits(UIFontDescriptor.SymbolicTraits(traits).union(self.fontDescriptor.symbolicTraits)) else {
return self
}
return UIFont(descriptor: descriptor, size: 0)
}
func without(_ traits: UIFontDescriptor.SymbolicTraits...) -> UIFont {
guard let descriptor = self.fontDescriptor.withSymbolicTraits(self.fontDescriptor.symbolicTraits.subtracting(UIFontDescriptor.SymbolicTraits(traits))) else {
return self
}
return UIFont(descriptor: descriptor, size: 0)
}
}
return withTraits(.TraitBold, .TraitCondensed)
おそらくreturn withTraits(.TraitBold, .TraitItalic)
、関数名と一致するはずです。
@Edinatorはこれを見てください。
myLabel.font = [UIFont boldSystemFontOfSize:16.0f]
myLabel.font = [UIFont italicSystemFontOfSize:16.0f];
上記のいずれかを必要なときに使用する
ラベルとボタンに太字と斜体の両方を適用する必要がある同じ問題があります。次のコードを使用して、この効果を実現できます。
myLabel.font = [UIFont fontWithName:@"Arial-BoldItalic" size:30.0];
iOS 7のシステムデフォルトフォントでは、システムデフォルトフォントを維持したい場合は、helvetica neue boldを使用します。
[titleText setFont:[UIFont fontWithName:@"HelveticaNeue-Bold" size:16.0]];
または、単にそれを呼び出すことができます:
[titleText setFont:[UIFont boldSystemFontOfSize:16.0]];
btn.titleLabel.font=[UIFont fontWithName:@"Helvetica neue" size:10];
btn.titleLabel.font = [UIFont boldSystemFontOfSize:btnPrev.titleLabel.font.pointSize+3];
あなたもこれを使用して太字のラベル/ボタンフォントを行うことができます
特性を追加または削除できるマクシミリアンウォジャコウスキーの応答のバリエーションを作成しました
extension UIFont {
func withTraits(_ traits:UIFontDescriptorSymbolicTraits...) -> UIFont {
let descriptor = self.fontDescriptor
.withSymbolicTraits(UIFontDescriptorSymbolicTraits(traits).union(self.fontDescriptor.symbolicTraits))
return UIFont(descriptor: descriptor!, size: 0)
}
func withoutTraits(_ traits:UIFontDescriptorSymbolicTraits...) -> UIFont {
let descriptor = self.fontDescriptor
.withSymbolicTraits( self.fontDescriptor.symbolicTraits.subtracting(UIFontDescriptorSymbolicTraits(traits)))
return UIFont(descriptor: descriptor!, size: 0)
}
func bold() -> UIFont {
return withTraits( .traitBold)
}
func italic() -> UIFont {
return withTraits(.traitItalic)
}
func noItalic() -> UIFont {
return withoutTraits(.traitItalic)
}
func noBold() -> UIFont {
return withoutTraits(.traitBold)
}
}
例
label.font = label.font.italic().bold()
セルを再利用し、前のセルのラベルに付けた斜体を削除する場合に便利です
これらの回答ですでに述べたように、必要なのは適切なフォント名だけです。私はそれを見つける iOSFonts.comが使用する正確に何名を知るための最も有用なリソースです。
太字の例:
UILabel *titleBold = [[UILabel alloc] initWithFrame:CGRectMake(10, 10, 200, 30)];
UIFont* myBoldFont = [UIFont boldSystemFontOfSize:[UIFont systemFontSize]];
[titleBold setFont:myBoldFont];
斜体の例:
UILabel *subTitleItalic = [[UILabel alloc] initWithFrame:CGRectMake(10, 35, 200, 30)];
UIFont* myItalicFont = [UIFont italicSystemFontOfSize:[UIFont systemFontSize]];
[subTitleItalic setFont:myItalicFont];
@tolbardによって提供された答えは素晴らしく、うまく機能しますが!
たった1行のコードで実現できる拡張機能を作成するのは、やりすぎだと思います。
以下のSwift 4.0を使用した例に示すようにfontプロパティを設定することで、同じテキストに対して太字およびイタリックのスタイルを取得できます。 label
UIFontDescriptor
label.font = UIFont(descriptor: UIFontDescriptor().withSymbolicTraits([.traitBold, .traitItalic])!, size: 12)
その他のオプションは次のとおりです。
traitLooseLeading
traitTightLeading
traitUIOptimized
traitVertical
traitMonoSpace
traitCondensed
traitExpanded
それらの象徴的な特徴が何を意味するかについての詳細情報は?こちらをご覧ください
Maksymilian Wojakowskiのすばやい3の素晴らしい答えを更新する
extension UIFont {
func withTraits(traits:UIFontDescriptorSymbolicTraits...) -> UIFont? {
guard let descriptorL = self.fontDescriptor.withSymbolicTraits(UIFontDescriptorSymbolicTraits(traits)) else{
return nil
}
return UIFont(descriptor: descriptorL, size: 0)
}
func boldItalic() -> UIFont? {
return withTraits(traits: .traitBold, .traitItalic)
}
}
これはとても簡単です。これがコードです。
[yourLabel setFont:[UIFont boldSystemFontOfSize:15.0];
これはあなたを助けます。
多くの場合、太字のテキストは別のレベルで情報アーキテクチャの方法で見なされるため、1行で太字で規則的ではないため、1つの規則と太字の斜体で2つのラベル/ textViewに分割できます。エディタを使用してフォントスタイルを選択します。