Uisegmentedcontrolのフォントサイズとフォント名をプログラムで変更する方法私はSwiftを使用しました。
ここに私のコードがあります:
self.mysegmentedControl = UISegmentedControl(items: [
NSLocalizedString("Aaaaaa", comment: ""),
NSLocalizedString("Bbbbbb", comment: ""),
NSLocalizedString("Cccccc", comment: ""),
NSLocalizedString("Dddddd", comment: ""),
NSLocalizedString("Eeeeee", comment: ""),
])
self.mysegmentedControl.addTarget(self, action: "mysegmentedControlDidChange:", forControlEvents: .ValueChanged)
self.mysegmentedControl.selectedSegmentIndex = 0
よろしく。
UIはコントロールの外観を使用できます。追加するのに最適な場所はアプリデリゲート、didFinishLaunchingWithOptions
メソッドです。プロジェクト内のすべてのUISegmentedControlsに一度だけ同じ属性を設定する場合は、これを使用します。
let attr = NSDictionary(object: UIFont(name: "HelveticaNeue-Bold", size: 16.0)!, forKey: NSFontAttributeName)
UISegmentedControl.appearance().setTitleTextAttributes(attr as [NSObject : AnyObject] , forState: .Normal)
ただし、1つのUISegmentedControlのみに属性を設定する場合、または特定の条件に基づいてより頻繁に属性を変更する場合は、UISegmentedControlメソッドを使用します。
func setTitleTextAttributes(_ attributes: [NSObject : AnyObject]?,
forState state: UIControlState)
例:
let attr = NSDictionary(object: UIFont(name: "HelveticaNeue-Bold", size: 16.0)!, forKey: NSFontAttributeName)
seg.setTitleTextAttributes(attr as [NSObject : AnyObject] , forState: .Normal)
Swift 4
let font: [AnyHashable : Any] = [NSAttributedStringKey.font : UIFont.systemFont(ofSize: 17)]
segmentedControl.setTitleTextAttributes(font, for: .normal)
この回答は日付が付けられていますが、Swift=
func stylizeFonts(){
let normalFont = UIFont(name: "Helvetica", size: 16.0)
let boldFont = UIFont(name: "Helvetica-Bold", size: 16.0)
let normalTextAttributes: [NSObject : AnyObject] = [
NSForegroundColorAttributeName: UIColor.blackColor(),
NSFontAttributeName: normalFont!
]
let boldTextAttributes: [NSObject : AnyObject] = [
NSForegroundColorAttributeName : UIColor.whiteColor(),
NSFontAttributeName : boldFont!,
]
self.setTitleTextAttributes(normalTextAttributes, forState: .Normal)
self.setTitleTextAttributes(normalTextAttributes, forState: .Highlighted)
self.setTitleTextAttributes(boldTextAttributes, forState: .Selected)
}
ViewDidLoadに、またはサブクラス化する場合は別の関数として、必ずstylizeFonts()を追加してください。
Gregの回答がSwift3用に更新されました:
let attr = NSDictionary(object: UIFont(name: "OpenSans", size: 12.0)!, forKey: NSFontAttributeName as NSCopying)
UISegmentedControl.appearance().setTitleTextAttributes(attr as [NSObject : AnyObject] , for: .normal)
Swift 2.
override func viewDidLayoutSubviews() {
let attributedSegmentFont = NSDictionary(object: UIFont(name: "Roboto-Regular", size: 14.0)!, forKey: NSFontAttributeName)
dashBoardSegment.setTitleTextAttributes(attributedSegmentFont as [NSObject : AnyObject], forState: .Normal)
}
すべてのセグメントコントロールの変更、使用:
UISegmentedControl.appearance().setTitleTextAttributes(attributedSegmentFont as [NSObject : AnyObject], forState: .Normal)
Swift Extension:を使用
extension UISegmentedControl{
func changeTitleFont(newFontName:String?, newFontSize:CGFloat?){
let attributedSegmentFont = NSDictionary(object: UIFont(name: newFontName!, size: newFontSize!)!, forKey: NSFontAttributeName)
setTitleTextAttributes(attributedSegmentFont as [NSObject : AnyObject], forState: .Normal)
}
}
拡張機能の実装:
override func viewDidLayoutSubviews() {
dashBoardSegment.changeTitleFont("Roboto-Regular", newFontSize: 14.0)
}
Swift
override func viewDidLayoutSubviews() {
let attr = NSDictionary(object: UIFont(name: "Chalkduster", size: 14.0)!, forKey: NSFontAttributeName as NSCopying)
segmentedControl.setTitleTextAttributes(attr as [NSObject : AnyObject] , for: .normal)
}
Mvienの優れたSwiftアプローチを拡張する方法です。SegmentedControl拡張を作成しました。
extension UISegmentedControl {
func setFontSize(fontSize: CGFloat) {
let normalTextAttributes: [NSObject : AnyObject] = [
NSForegroundColorAttributeName: UIColor.blackColor(),
NSFontAttributeName: UIFont.systemFontOfSize(fontSize, weight: UIFontWeightRegular)
]
let boldTextAttributes: [NSObject : AnyObject] = [
NSForegroundColorAttributeName : UIColor.whiteColor(),
NSFontAttributeName : UIFont.systemFontOfSize(fontSize, weight: UIFontWeightMedium),
]
self.setTitleTextAttributes(normalTextAttributes, forState: .Normal)
self.setTitleTextAttributes(normalTextAttributes, forState: .Highlighted)
self.setTitleTextAttributes(boldTextAttributes, forState: .Selected)
}
}
上記の拡張コードをプロジェクトに追加して、次のように使用します。
yourSegmentedControl.setFontSize(20)
Swift 4
let font = UIFont.systemFont(ofSize: 16)
segmentedControl.setTitleTextAttributes([NSAttributedString.Key.font: font],
for: .normal)
それを操作するために拡張機能を追加することは素晴らしいアイデアだと思うので、@ Alvin Georgeの答えを使用します(そしてSwift 4)のためにそれを改善します):
UISegmentedControl+Additions.Swift
のようなUISegmentedControlの拡張クラスを作成します
import Foundation
import UIKit
extension UISegmentedControl {
func font(name:String?, size:CGFloat?) {
let attributedSegmentFont = NSDictionary(object: UIFont(name: name!, size: size!)!, forKey: NSAttributedStringKey.font as NSCopying)
setTitleTextAttributes(attributedSegmentFont as [NSObject : AnyObject], for: .normal)
}
}
コードで使用してください:
segmentedControl?.font(name: "My Font Name", size: 12)
承認済みの回答に基づいてUIAppearanceで変更する場合の内訳は次のとおりです。
var font = UIFont.FromName("HelveticaNeue-Bold", 16f);
var textAttributes = new UITextAttributes { Font = font };
UISegmentedControl.Appearance.SetTitleTextAttributes(textAttributes,
UIControlState.Normal);
Swift 4
@IBOutlet var sgmentTypeSelect: UISegmentedControl!{
didSet {
let normalTextAttributes: [NSAttributedStringKey : AnyObject] = [
NSAttributedStringKey.foregroundColor : UIColor.themeGold,
NSAttributedStringKey.font : UIFont.defaultMontserratFont(style: "SemiBold", size: 13)
]
let selectedTextAttributes: [NSAttributedStringKey : AnyObject] = [
NSAttributedStringKey.foregroundColor : UIColor.black,
NSAttributedStringKey.font : UIFont.defaultMontserratFont(style: "Bold", size: 13)
]
sgmentTypeSelect.setTitleTextAttributes(normalTextAttributes, for: .normal)
sgmentTypeSelect.setTitleTextAttributes(normalTextAttributes, for: .highlighted)
sgmentTypeSelect.setTitleTextAttributes(selectedTextAttributes, for: .selected)
}
}