|
|
|
|
|
func setTitle(title:String, subtitle:String) -> UIView { |
|
let titleLabel = UILabel(frame: CGRect(x:0, y:-5, width:0, height:0)) |
|
|
|
titleLabel.backgroundColor = UIColor.clear |
|
titleLabel.textColor = UIColor.gray |
|
titleLabel.font = UIFont.boldSystemFont(ofSize: 17) |
|
titleLabel.text = title |
|
titleLabel.sizeToFit() |
|
|
|
let subtitleLabel = UILabel(frame: CGRect(x:0, y:18, width:0, height:0)) |
|
subtitleLabel.backgroundColor = UIColor.clear |
|
subtitleLabel.textColor = UIColor.black |
|
subtitleLabel.font = UIFont.systemFont(ofSize: 12) |
|
subtitleLabel.text = subtitle |
|
subtitleLabel.sizeToFit() |
|
|
|
let titleView = UIView(frame: CGRect(x:0, y:0, width:max(titleLabel.frame.size.width, subtitleLabel.frame.size.width), height:30)) |
|
titleView.addSubview(titleLabel) |
|
titleView.addSubview(subtitleLabel) |
|
|
|
let widthDiff = subtitleLabel.frame.size.width - titleLabel.frame.size.width |
|
|
|
if widthDiff > 0 { |
|
var frame = titleLabel.frame |
|
frame.origin.x = widthDiff / 2 |
|
titleLabel.frame = frame.integral |
|
} else { |
|
var frame = subtitleLabel.frame |
|
frame.origin.x = abs(widthDiff) / 2 |
|
titleLabel.frame = frame.integral |
|
} |
|
|
|
return titleView |
|
} |
|
|
|
|
|
// Use : |
|
self.navigationItem.titleView = setTitle("title", "subtitle") |
|
|
|
// Source : http://stackoverflow.com/questions/12914004/uinavigationbar-titleview-with-subtitle |
|
|
I joined @odonckers and @blinkelvin code together
here is an example of how to use it
I notice it looks very good with Regular NavigationBar
but with Large NavigationBar it stays on the same size
it needs to improve with Large Navigation bar