自定义按钮在禁用时不显示为灰色

时间:2019-05-13 18:02:28

标签: swift

我创建了一个自定义按钮,并且将其设置为未启用时显示为灰色。但是,当我运行该程序时,禁用的按钮不会变灰。我怎么可能做错了。

自定义按钮类别:

import UIKit

class CustomButton: UIButton {

    override init (frame: CGRect){
        super.init(frame: frame)
        config()
    }

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        config()
    }

    func config(){

        // Setting disabled/enabled traits
        setTitleColor(UIColor.gray, for: UIControl.State.disabled)
        setTitleColor(UIColor.gray, for: UIControl.State.normal)


        if !isEnabled{
            backgroundColor = UIColor.gray
        }else{
            backgroundColor = UIColor.white
        }

        // Other styling options
        layer.cornerRadius = 10

        // Making it look 3D
        layer.shadowColor = UIColor(red: 0.0, green: 0, blue: 0, alpha: 1.0).cgColor
        layer.shadowOpacity = 1.0
        layer.shadowRadius = 1.0
        layer.shadowOffset = CGSize(width: 0, height: 1)
    }

}

按钮初始化(也在情节提要中设置)

    @IBOutlet weak var movePickPosBut: CustomButton!

1 个答案:

答案 0 :(得分:0)

您根据isEnabled状态设置的背景颜色是静态的,而不是动态的;也就是说,在构建按钮时,您要检查它是否已启用(可能已启用),并相应地设置背景色。但是,更改isEnabled标志时,此情况不会更改。

请使用系统功能根据状态控制背景。因此,请替换此代码:-

if !isEnabled{
    backgroundColor = UIColor.gray
}else{
    backgroundColor = UIColor.white
}

与此:-

self.setBackgroundColor(UIColor.gray, for: .disabled)

这将使背景色与状态保持关联。

您还将需要这段代码,该代码是我从this article摘录的(可能会提供进一步的帮助)。

extension UIButton {

  private func image(withColor color: UIColor) -> UIImage? {
    let rect = CGRect(x: 0.0, y: 0.0, width: 1.0, height: 1.0)
    UIGraphicsBeginImageContext(rect.size)
    let context = UIGraphicsGetCurrentContext()

    context?.setFillColor(color.cgColor)
    context?.fill(rect)

    let image = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()

    return image
  }

  func setBackgroundColor(_ color: UIColor, for state: UIControlState) {
    self.setBackgroundImage(image(withColor: color), for: state)
  }
}