如何正确自动缩放 UIButton 和标题文本?

Posted

技术标签:

【中文标题】如何正确自动缩放 UIButton 和标题文本?【英文标题】:How to autoscale UIButton and title text correctly? 【发布时间】:2018-09-28 21:59:52 【问题描述】:

我正在尝试制作带有标题的按钮,这些标题会根据 ios 设备(自动缩放)改变标题文本的宽度、高度和字体大小。我正在使用 Xcode 10 编码 Swift。

这是一个简单的例子:我在 IB 中创建了覆盖整个屏幕的红色按钮(顶部、底部、前导和尾随约束设置为 0),标题为“按钮”在中心,字体大小设置为 350 . 标题完全适合 12.9 英寸 iPad 的宽度(见图)。

我这样输入 FitToWidth 代码:

class ViewController: UIViewController 

@IBOutlet weak var button: UIButton!

override func viewDidLoad() 
    super.viewDidLoad()
    // Do any additional setup after loading the view, typically from a nib.
    button.titleLabel?.adjustsFontSizeToFitWidth = true
    button.titleLabel?.minimumScaleFactor = 0.1

当我在屏幕分辨率低于 iPad 12.9 的设备上运行代码时,我看到按钮标题已缩放并适合屏幕宽度,但它已向下移动(参见图片)。

iPad 12.9 模拟

iPhone SE 模拟

我错过了什么?

我需要标题文本位于按钮的中心,就像我在 IB 中所做的那样。我尝试了应用于按钮的各种约束,但没有任何结果。

【问题讨论】:

【参考方案1】:

看来我找到了解决办法。

我刚刚在 viewDidLoad 的代码中添加了这样的字符串: button.titleLabel?.baselineAdjustment = UIBaselineAdjustment.alignCenters

现在标题位于任何 iOS 设备的按钮中间:

【讨论】:

【参考方案2】:

调整按钮视图的大小以使标题适合每个屏幕尺寸

在 viewDidAppear() 中试试这个

button.sizeToFit() 

【讨论】:

不幸的是,它并没有解决我的问题 - 按钮重新缩放后按钮标题仍然向下移动。

以上是关于如何正确自动缩放 UIButton 和标题文本?的主要内容,如果未能解决你的问题,请参考以下文章

如何通过 IOS 7 中的文本自动调整 UIButton 的大小?

自动缩小的 UIButton 文本之前的换行符

如何将图像 UIButton 缩放到插图?

如何正确地将 UIButton 中的图像放入图像中?

缩放 UIImage 以适应 UIButton 的问题

iOS 和 Xcode 6:按钮上的自动布局文本缩放