1

我有一个使用自定义按钮的应用程序,按钮应该只是有一个背景图像。我宁愿拥有一个 UIButton 子类,而不是将背景图像添加到所有按钮。如果自定义按钮也在 Interface Builder 中正确呈现,那就太好了。这是我迄今为止的尝试:

import UIKit

@IBDesignable
class STACPatientButton: UIButton {

    override init(frame: CGRect) {
        NSLog("initWithFrame");
        super.init(frame: frame)
        _setup()
    }

    required init(coder: NSCoder) {
        NSLog("initWithCoder");
        super.init(coder: coder)
        _setup()
    }

    override func prepareForInterfaceBuilder() {
        _setup()
    }

    private func _setup() {
        if let image = UIImage(named:"patientButton.png") {
            let insets = UIEdgeInsetsMake(8.0, 8.0, 8.0, 8.0)
            let strechableImage = image.resizableImageWithCapInsets(insets)
            self.setBackgroundImage(strechableImage, forState: UIControlState.Normal)
            self.contentEdgeInsets = UIEdgeInsetsMake(16.0, 16.0, 16.0, 16.0)
            self.sizeToFit()
        }
    }

}

这是 patientButton.png

在此处输入图像描述

两个问题:

  1. 该按钮无法在 Interface Builder 中正确呈现。它只是显示为系统按钮
  2. 除非我在 Interface Builder 中调整按钮的大小以为图像留出空间,否则不会显示标题;即,该contentEdgeInsets属性sizeToFit似乎没有效果

我想这是一个非常基本的问题,但我无法解决。有什么建议吗?

根据下面与马特的讨论编辑 1:

我想要实现的是在按钮标题周围留出一些空间。这是我的理解,contentEdgeInsets但看起来我错了。没有contentEdgeInsets这个是按钮的渲染

在此处输入图像描述

这看起来很可怕。我想以编程方式得到这样的东西,而不必在 IB 中调整按钮的大小

在此处输入图像描述

4

1 回答 1

3

你误解了什么contentEdgeInsets。对于背景图像的插图,您需要实现此方法:

override func backgroundRectForBounds(bounds: CGRect) -> CGRect {
    return bounds.rectByInsetting(dx: 16, dy: 16)
}

对于 IBDesignable,您所做的在结构上是正确的;如果您删除_setup()代码并将其替换为

self.backgroundColor = UIColor.redColor()

该按钮实际上在 IB 中是红色的。所以也许 IB 只是不“做”在代码中设置的背景图像等等。

于 2015-06-28T20:24:18.977 回答